src/devices/wifi/dcf-manager-test.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Thu, 15 Nov 2007 14:29:06 +0100
changeset 2126 c2f1ec692e70
parent 2125 15ba30b939d1
child 2131 a43aabcfa388
permissions -rw-r--r--
ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     2
#ifdef RUN_SELF_TESTS
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     3
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     4
#include "ns3/test.h"
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     5
#include "ns3/simulator.h"
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     6
#include "dcf-manager.h"
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     7
#include "mac-parameters.h"
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     8
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
     9
namespace ns3 {
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    10
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    11
class DcfManagerTest;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    12
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    13
class DcfStateTest : public DcfState 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    14
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    15
public:
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    16
  DcfStateTest (DcfManagerTest *test, uint32_t i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    17
private:
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    18
  virtual bool NeedsAccess (void) const;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    19
  virtual void NotifyAccessGranted (void);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    20
  virtual void NotifyInternalCollision (void);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    21
  virtual void NotifyCollision (void);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    22
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    23
  DcfManagerTest *m_test;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    24
  uint32_t m_i;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    25
};
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    26
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    27
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    28
class DcfManagerTest : public Test
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    29
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    30
public:
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    31
  DcfManagerTest ();
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    32
  virtual bool RunTests (void);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    33
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    34
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    35
  void NotifyAccessGranted (uint32_t i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    36
  void NotifyInternalCollision (uint32_t i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    37
  void NotifyCollision (uint32_t i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    38
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    39
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    40
private:
2105
e883a100109a get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2104
diff changeset
    41
  void StartTest (uint64_t slotTime, uint64_t sifs, uint64_t ackTxDuration);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
    42
  void AddDcfState (uint32_t aifsn);
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    43
  void EndTest (void);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    44
  void ExpectAccessGranted (uint64_t time, uint32_t from);
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    45
  void ExpectInternalCollision (uint64_t time, uint32_t from, uint32_t nSlots);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    46
  void ExpectCollision (uint64_t time, uint32_t from, uint32_t nSlots);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    47
  void AddRxOkEvt (uint64_t at, uint64_t duration);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    48
  void AddRxErrorEvt (uint64_t at, uint64_t duration);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    49
  void AddTxEvt (uint64_t at, uint64_t duration);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    50
  void AddNavReset (uint64_t at, uint64_t duration);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    51
  void AddNavStart (uint64_t at, uint64_t duration);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    52
  void AddAccessRequest (uint64_t time, uint32_t from);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
    53
  
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    54
  struct ExpectedCollision {
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    55
    uint64_t at;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    56
    uint32_t from;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    57
    uint32_t nSlots;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    58
  };
2101
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
    59
  typedef std::vector<DcfStateTest *> DcfStates;
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    60
  typedef std::list<std::pair<uint64_t, uint32_t> > ExpectedAccess;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    61
  typedef std::list<struct ExpectedCollision> ExpectedCollisions;
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    62
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    63
  DcfManager *m_dcfManager;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    64
  MacParameters *m_parameters;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    65
  DcfStates m_dcfStates;
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    66
  ExpectedAccess m_expectedAccessGranted;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    67
  ExpectedCollisions m_expectedInternalCollision;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
    68
  ExpectedCollisions m_expectedCollision;
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    69
  bool m_result;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    70
};
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    71
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    72
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    73
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    74
DcfStateTest::DcfStateTest (DcfManagerTest *test, uint32_t i) 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    75
  : m_test (test), m_i(i)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    76
{}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    77
bool 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    78
DcfStateTest::NeedsAccess (void) const
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    79
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    80
  return true;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    81
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    82
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    83
DcfStateTest::NotifyAccessGranted (void)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    84
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    85
  m_test->NotifyAccessGranted (m_i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    86
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    87
void
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    88
DcfStateTest::NotifyInternalCollision (void)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    89
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    90
  m_test->NotifyInternalCollision (m_i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    91
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    92
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    93
DcfStateTest::NotifyCollision (void)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    94
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    95
  m_test->NotifyCollision (m_i);
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    96
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    97
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    98
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
    99
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   100
DcfManagerTest::DcfManagerTest ()
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   101
  : Test ("DcfManager")
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   102
{}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   103
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   104
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   105
DcfManagerTest::NotifyAccessGranted (uint32_t i)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   106
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   107
  bool result = true;
2102
694a2c0ccacc a few more test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2101
diff changeset
   108
  NS_TEST_ASSERT (!m_expectedAccessGranted.empty ());
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   109
  std::pair<uint64_t, uint32_t> expected = m_expectedAccessGranted.front ();
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   110
  m_expectedAccessGranted.pop_front ();
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   111
  NS_TEST_ASSERT_EQUAL (Simulator::Now (), MicroSeconds (expected.first));
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   112
  NS_TEST_ASSERT_EQUAL (i, expected.second);
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   113
  if (!result)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   114
    {
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   115
      m_result = result;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   116
    }
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   117
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   118
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   119
DcfManagerTest::NotifyInternalCollision (uint32_t i)
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   120
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   121
  bool result = true;
2102
694a2c0ccacc a few more test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2101
diff changeset
   122
  NS_TEST_ASSERT (!m_expectedInternalCollision.empty ());
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   123
  struct ExpectedCollision expected = m_expectedInternalCollision.front ();
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   124
  m_expectedInternalCollision.pop_front ();
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   125
  NS_TEST_ASSERT_EQUAL (Simulator::Now (), MicroSeconds (expected.at));
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   126
  NS_TEST_ASSERT_EQUAL (i, expected.from);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   127
  uint32_t k = 0;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   128
  for (DcfStates::const_iterator j = m_dcfStates.begin (); j != m_dcfStates.end (); j++, k++)
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   129
    {
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   130
      if (i == k)
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   131
        {
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   132
          DcfState *state = *j;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   133
          state->StartBackoffNow (expected.nSlots);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   134
        }
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   135
    }
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   136
  if (!result)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   137
    {
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   138
      m_result = result;
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   139
    }
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   140
}
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   141
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   142
DcfManagerTest::NotifyCollision (uint32_t i)
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   143
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   144
  bool result = true;
2102
694a2c0ccacc a few more test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2101
diff changeset
   145
  NS_TEST_ASSERT (!m_expectedCollision.empty ());
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   146
  struct ExpectedCollision expected = m_expectedCollision.front ();
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   147
  m_expectedCollision.pop_front ();
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   148
  NS_TEST_ASSERT_EQUAL (Simulator::Now (), MicroSeconds (expected.at));
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   149
  NS_TEST_ASSERT_EQUAL (i, expected.from);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   150
  DcfState *state = m_dcfStates[i];
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   151
  state->StartBackoffNow (expected.nSlots);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   152
  if (!result)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   153
    {
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   154
      m_result = result;
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   155
    }
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   156
}
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   157
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   158
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   159
void 
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   160
DcfManagerTest::ExpectAccessGranted (uint64_t time, uint32_t from)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   161
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   162
  m_expectedAccessGranted.push_back (std::make_pair (time, from));
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   163
}
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   164
void 
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   165
DcfManagerTest::ExpectInternalCollision (uint64_t time, uint32_t nSlots, uint32_t from)
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   166
{
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   167
  struct ExpectedCollision col;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   168
  col.at = time;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   169
  col.from = from;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   170
  col.nSlots = nSlots;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   171
  m_expectedInternalCollision.push_back (col);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   172
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   173
void 
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   174
DcfManagerTest::ExpectCollision (uint64_t time, uint32_t nSlots, uint32_t from)
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   175
{
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   176
  struct ExpectedCollision col;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   177
  col.at = time;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   178
  col.from = from;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   179
  col.nSlots = nSlots;
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   180
  m_expectedCollision.push_back (col);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   181
}
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   182
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   183
void
2105
e883a100109a get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2104
diff changeset
   184
DcfManagerTest::StartTest (uint64_t slotTime, uint64_t sifs, uint64_t ackTxDuration)
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   185
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   186
  m_dcfManager = new DcfManager ();
2105
e883a100109a get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2104
diff changeset
   187
  m_dcfManager->SetSlotTime (MicroSeconds (slotTime));
e883a100109a get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2104
diff changeset
   188
  m_dcfManager->SetSifs (MicroSeconds (sifs));
2104
1ba670fdde06 more debugging.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2103
diff changeset
   189
  m_dcfManager->SetAckTxDuration (MicroSeconds (ackTxDuration));
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   190
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   191
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   192
void
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   193
DcfManagerTest::AddDcfState (uint32_t aifsn)
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   194
{
2101
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   195
  DcfStateTest *state = new DcfStateTest (this, m_dcfStates.size ());
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   196
  state->SetAifsn (aifsn);
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   197
  m_dcfStates.push_back (state);
2101
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   198
  m_dcfManager->Add (state);
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   199
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   200
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   201
void
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   202
DcfManagerTest::EndTest (void)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   203
{
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   204
  bool result = true;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   205
  Simulator::Run ();
2110
b49dc66e635b remove buggy test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2105
diff changeset
   206
  NS_TEST_ASSERT (m_expectedAccessGranted.empty ());
b49dc66e635b remove buggy test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2105
diff changeset
   207
  NS_TEST_ASSERT (m_expectedInternalCollision.empty ());
b49dc66e635b remove buggy test asserts
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2105
diff changeset
   208
  NS_TEST_ASSERT (m_expectedCollision.empty ());
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   209
  Simulator::Destroy ();
2101
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   210
  for (DcfStates::const_iterator i = m_dcfStates.begin (); i != m_dcfStates.end (); i++)
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   211
    {
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   212
      delete *i;
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   213
    }
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   214
  m_dcfStates.clear ();
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   215
  delete m_dcfManager;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   216
  delete m_parameters;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   217
  if (!result)
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   218
    {
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   219
      m_result = result;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   220
    }
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   221
}
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   222
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   223
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   224
DcfManagerTest::AddRxOkEvt (uint64_t at, uint64_t duration)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   225
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   226
  Simulator::Schedule (MicroSeconds (at) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   227
                       &DcfManager::NotifyRxStartNow, m_dcfManager, 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   228
                       MicroSeconds (duration));
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   229
  Simulator::Schedule (MicroSeconds (at+duration) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   230
                       &DcfManager::NotifyRxEndOkNow, m_dcfManager);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   231
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   232
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   233
DcfManagerTest::AddRxErrorEvt (uint64_t at, uint64_t duration)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   234
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   235
  Simulator::Schedule (MicroSeconds (at) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   236
                       &DcfManager::NotifyRxStartNow, m_dcfManager, 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   237
                       MicroSeconds (duration));
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   238
  Simulator::Schedule (MicroSeconds (at+duration) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   239
                       &DcfManager::NotifyRxEndErrorNow, m_dcfManager);
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   240
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   241
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   242
DcfManagerTest::AddTxEvt (uint64_t at, uint64_t duration)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   243
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   244
  Simulator::Schedule (MicroSeconds (at) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   245
                       &DcfManager::NotifyTxStartNow, m_dcfManager, 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   246
                       MicroSeconds (duration));
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   247
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   248
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   249
DcfManagerTest::AddNavReset (uint64_t at, uint64_t duration)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   250
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   251
  Simulator::Schedule (MicroSeconds (at) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   252
                       &DcfManager::NotifyNavResetNow, m_dcfManager, 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   253
                       MicroSeconds (duration));
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   254
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   255
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   256
DcfManagerTest::AddNavStart (uint64_t at, uint64_t duration)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   257
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   258
  Simulator::Schedule (MicroSeconds (at) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   259
                       &DcfManager::NotifyNavStartNow, m_dcfManager, 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   260
                       MicroSeconds (duration));
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   261
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   262
void 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   263
DcfManagerTest::AddAccessRequest (uint64_t time, uint32_t from)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   264
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   265
  Simulator::Schedule (MicroSeconds (time) - Now (), 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   266
                       &DcfManager::RequestAccess, 
2101
05c4a31c0a58 simplify memory management
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2098
diff changeset
   267
		       m_dcfManager, m_dcfStates[from]);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   268
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   269
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   270
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   271
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   272
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   273
bool 
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   274
DcfManagerTest::RunTests (void)
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   275
{
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   276
  m_result = true;
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   277
2105
e883a100109a get rid of MacParameters from DcfManager
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2104
diff changeset
   278
  StartTest (1 /* slot time */, 3 /* sifs */, 10 /* ack tx dur */);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   279
  AddDcfState (1);
2113
40048ae9496a add a new test
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2110
diff changeset
   280
  AddAccessRequest (1 /* at */ , 0 /* from */);
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   281
  ExpectAccessGranted (4, 0);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   282
  AddAccessRequest (10, 0);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   283
  ExpectAccessGranted (10, 0);
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   284
  EndTest ();
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   285
2121
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   286
  // The test below mainly intends to test the case where the medium
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   287
  // becomes busy in the middle of a backoff slot: the backoff counter
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   288
  // must not be decremented for this backoff slot. This is the case
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   289
  // below for the backoff slot starting at time 78us.
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   290
  //
2119
faa2af6508b4 forgot sifs + aifsn for test
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2118
diff changeset
   291
  //  20          60     66      70        74        78  80    100     106      110      114      118
faa2af6508b4 forgot sifs + aifsn for test
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2118
diff changeset
   292
  //   |    rx     | sifs | aifsn | bslot0  | bslot1  |   | rx   | sifs  |  aifsn | bslot2 | bslot3 |
2121
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   293
  //        |
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   294
  //       30 request access. backoff slots: 4
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   295
  StartTest (4, 6 , 10);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   296
  AddDcfState (1);
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   297
  AddRxOkEvt (20, 40);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   298
  AddRxOkEvt (80, 20);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   299
  AddAccessRequest (30, 0);
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   300
  ExpectCollision (30, 4, 0); // backoff: 4 slots
2119
faa2af6508b4 forgot sifs + aifsn for test
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2118
diff changeset
   301
  ExpectAccessGranted (118, 0);
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   302
  EndTest ();
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   303
2124
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   304
  // Test the case where the backoff slots is zero.
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   305
  //
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   306
  //  20          60     66      70
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   307
  //   |    rx     | sifs | aifsn |
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   308
  //        |
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   309
  //       30 request access. backoff slots: 0
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   310
  StartTest (4, 6 , 10);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   311
  AddDcfState (1);
2124
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   312
  AddRxOkEvt (20, 40);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   313
  AddAccessRequest (30, 0);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   314
  ExpectCollision (30, 0, 0); // backoff: 0 slots
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   315
  ExpectAccessGranted (70, 0);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   316
  EndTest ();
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   317
2121
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   318
  // The test below is subject to some discussion because I am 
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   319
  // not sure I understand the intent of the spec here.
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   320
  // i.e., what happens if you make a request to get access
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   321
  // to the medium during the difs idle time after a busy period ?
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   322
  // do you need to start a backoff ? Or do you need to wait until
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   323
  // the end of difs and access the medium ?
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   324
  // Here, we wait until the end of difs and access the medium.
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   325
  //
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   326
  //  20    60     66      70
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   327
  //   | rx  | sifs | aifsn |
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   328
  //           |
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   329
  //          62 request access.
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   330
  //
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   331
  StartTest (4, 6 , 10);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   332
  AddDcfState (1);
2121
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   333
  AddRxOkEvt (20, 40);
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   334
  AddAccessRequest (62, 0);
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   335
  ExpectAccessGranted (70, 0);
60c0176e2389 a new test-case with some comments
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2119
diff changeset
   336
  EndTest ();
2118
864b31ff0c01 add a new test-case
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2113
diff changeset
   337
2124
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   338
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   339
  // Test an EIFS
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   340
  // 
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   341
  //  20          60     66           76      80       84       88       92       96
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   342
  //   |    rx     | sifs | acktxttime | aifsn | bslot0 | bslot1 | bslot2 | bslot3 |
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   343
  //        |      | <---------eifs----------->|
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   344
  //       30 request access. backoff slots: 4
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   345
  StartTest (4, 6, 10);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   346
  AddDcfState (1);
2124
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   347
  AddRxErrorEvt (20, 40);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   348
  AddAccessRequest (30, 0);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   349
  ExpectCollision (30, 4, 0); // backoff: 4 slots  
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   350
  ExpectAccessGranted (96, 0);
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   351
  EndTest ();
d95795a9767f more working tests.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2121
diff changeset
   352
2125
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   353
  // Test an EIFS which is interupted by a successfull transmission.
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   354
  // 
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   355
  //  20          60      66  69     75     81      85       89       93       97      101
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   356
  //   |    rx     | sifs  |   |  rx  | sifs | aifsn | bslot0 | bslot1 | bslot2 | bslot3 |
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   357
  //        |      | <--eifs-->|
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   358
  //       30 request access. backoff slots: 4
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   359
  StartTest (4, 6, 10);
2126
c2f1ec692e70 ignore cwmin/cwmax parameters since we set the backoff slots for every collision.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2125
diff changeset
   360
  AddDcfState (1);
2125
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   361
  AddRxErrorEvt (20, 40);
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   362
  AddAccessRequest (30, 0);
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   363
  ExpectCollision (30, 4, 0); // backoff: 4 slots  
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   364
  AddRxOkEvt (69, 6);
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   365
  ExpectAccessGranted (101, 0);
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   366
  EndTest ();
15ba30b939d1 test interupted eifs
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2124
diff changeset
   367
2098
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   368
  return m_result;
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   369
}
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   370
eb30083ad5f5 setup a simple test scenario
mlacage@thira.inria.fr
parents: 2097
diff changeset
   371
2097
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   372
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   373
static DcfManagerTest g_dcf_manager_test;
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   374
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   375
} // namespace ns3
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   376
dc2ee3f4e46b dcf test framework
mlacage@thira.inria.fr
parents:
diff changeset
   377
#endif /* RUN_SELF_TESTS */