A Discrete-Event Network Simulator
API
ThreeGppHttpClientServerTestSuite Class Reference

A test class for running several system tests which validate the web browsing traffic model. More...

+ Inheritance diagram for ThreeGppHttpClientServerTestSuite:
+ Collaboration diagram for ThreeGppHttpClientServerTestSuite:

Public Member Functions

 ThreeGppHttpClientServerTestSuite ()
 Instantiate the test suite. More...
 
- Public Member Functions inherited from ns3::TestSuite
 TestSuite (std::string name, Type type=UNIT)
 Construct a new test suite. More...
 
TestSuite::Type GetTestType (void)
 get the kind of test this test suite implements More...
 
- Public Member Functions inherited from ns3::TestCase
virtual ~TestCase ()
 Destructor. More...
 
std::string GetName (void) const
 

Private Member Functions

void AddHttpObjectTestCase (uint32_t rngRun, const Time &channelDelay, double bitErrorRate, uint32_t mtuSize, bool useIpv6)
 Creates a test case with the given parameters. More...
 

Additional Inherited Members

- Public Types inherited from ns3::TestSuite
enum  Type {
  ALL = 0, BVT = 1, UNIT, SYSTEM,
  EXAMPLE, PERFORMANCE
}
 Type of test. More...
 
- Public Types inherited from ns3::TestCase
enum  TestDuration { QUICK = 1, EXTENSIVE = 2, TAKES_FOREVER = 3 }
 How long the test takes to execute. More...
 
- Protected Member Functions inherited from ns3::TestCase
 TestCase (std::string name)
 Constructor. More...
 
void AddTestCase (TestCase *testCase, TestDuration duration=QUICK)
 Add an individual child TestCase to this test suite. More...
 
TestCaseGetParent () const
 Get the parent of this TestCsse. More...
 
bool IsStatusFailure (void) const
 Check if any tests failed. More...
 
bool IsStatusSuccess (void) const
 Check if all tests passed. More...
 
void SetDataDir (std::string directory)
 Set the data directory where reference trace files can be found. More...
 
void ReportTestFailure (std::string cond, std::string actual, std::string limit, std::string message, std::string file, int32_t line)
 Log the failure of this TestCase. More...
 
bool MustAssertOnFailure (void) const
 Check if this run should assert on failure. More...
 
bool MustContinueOnFailure (void) const
 Check if this run should continue on failure. More...
 
std::string CreateDataDirFilename (std::string filename)
 Construct the full path to a file in the data directory. More...
 
std::string CreateTempDirFilename (std::string filename)
 Construct the full path to a file in a temporary directory. More...
 

Detailed Description

A test class for running several system tests which validate the web browsing traffic model.

The tests cover the combinations of the following parameters:

  • the use of NewReno (ns-3's default)
  • various lengths of channel delay: 3 ms, 30 ms, and 300 ms;
  • the existence of transmission error;
  • different MTU (maximum transmission unit) sizes;
  • IPv4 and IPv6; and
  • the use of different set of random numbers.

The fullness parameter specified when running the test framework will determine the number of test cases created by this test suite.

Definition at line 802 of file three-gpp-http-client-server-test.cc.

Constructor & Destructor Documentation

◆ ThreeGppHttpClientServerTestSuite()

ThreeGppHttpClientServerTestSuite::ThreeGppHttpClientServerTestSuite ( )
inline

Instantiate the test suite.

Definition at line 806 of file three-gpp-http-client-server-test.cc.

References ns3::MilliSeconds().

+ Here is the call graph for this function:

Member Function Documentation

◆ AddHttpObjectTestCase()

void ThreeGppHttpClientServerTestSuite::AddHttpObjectTestCase ( uint32_t  rngRun,
const Time channelDelay,
double  bitErrorRate,
uint32_t  mtuSize,
bool  useIpv6 
)
inlineprivate

Creates a test case with the given parameters.

Parameters
rngRunRun index to be used, intended to affect the values produced by random number generators throughout the test.
channelDelayTransmission delay between the client and the server (and vice versa) which is due to the channel.
bitErrorRateThe probability of transmission error between the client and the server (and vice versa) in the unit of bits.
mtuSizeMaximum transmission unit (in bytes) to be used by the server model.
useIpv6If true, IPv6 will be used to address both client and server. Otherwise, IPv4 will be used.

Definition at line 862 of file three-gpp-http-client-server-test.cc.

References ns3::TestCase::AddTestCase(), and ns3::Time::GetMilliSeconds().

+ Here is the call graph for this function:

The documentation for this class was generated from the following file: