A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
FlameRegressionTest Class Reference

FLAME protocol regression test of three stations: More...

#include "flame-regression.h"

+ Inheritance diagram for FlameRegressionTest:
+ Collaboration diagram for FlameRegressionTest:

Public Member Functions

 FlameRegressionTest ()
 
 ~FlameRegressionTest () override
 
void CheckResults ()
 Check results function.
 
void DoRun () override
 Implementation to actually run this TestCase.
 
- Public Member Functions inherited from ns3::TestCase
 TestCase (const TestCase &)=delete
 
virtual ~TestCase ()
 Destructor.
 
std::string GetName () const
 
TestCaseoperator= (const TestCase &)=delete
 

Private Member Functions

void CreateDevices ()
 Create devices function.
 
void CreateNodes ()
 Create nodes function.
 
void HandleReadClient (Ptr< Socket > socket)
 Handle a packet reception.
 
void HandleReadServer (Ptr< Socket > socket)
 Handle a packet reception.
 
void InstallApplications ()
 Install application function.
 
void SendData (Ptr< Socket > socket)
 Send data.
 

Private Attributes

Ptr< Socketm_clientSocket
 Client-side socket.
 
Ipv4InterfaceContainer m_interfaces
 Needed to install applications.
 
NodeContainerm_nodes
 
uint32_t m_sentPktsCounter
 sent packets counter
 
Ptr< Socketm_serverSocket
 Server-side socket.
 
Time m_time
 Simulation time.
 

Additional Inherited Members

- Public Types inherited from ns3::TestCase
enum class  Duration { QUICK = 1 , EXTENSIVE = 2 , TAKES_FOREVER = 3 }
 How long the test takes to execute. More...
 
using instead = Duration
 
- Static Public Attributes inherited from ns3::TestCase
static constexpr auto EXTENSIVE = Duration::EXTENSIVE
 
static constexpr auto QUICK = Duration::QUICK
 
static constexpr auto TAKES_FOREVER
 
- Protected Member Functions inherited from ns3::TestCase
 TestCase (std::string name)
 Constructor.
 
void AddTestCase (TestCase *testCase, Duration duration=Duration::QUICK)
 Add an individual child TestCase to this test suite.
 
TestCaseGetParent () const
 Get the parent of this TestCase.
 
bool IsStatusFailure () const
 Check if any tests failed.
 
bool IsStatusSuccess () const
 Check if all tests passed.
 
void SetDataDir (std::string directory)
 Set the data directory where reference trace files can be found.
 
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.
 
bool MustAssertOnFailure () const
 Check if this run should assert on failure.
 
bool MustContinueOnFailure () const
 Check if this run should continue on failure.
 
std::string CreateDataDirFilename (std::string filename)
 Construct the full path to a file in the data directory.
 
std::string CreateTempDirFilename (std::string filename)
 Construct the full path to a file in a temporary directory.
 

Detailed Description

FLAME protocol regression test of three stations:

* <-----------|----------->   Broadcast frame
*             |----------->|  Unicast frame
*           Source                   Destination
* (node ID)   2            1            0
* <-----------|----------->|            |             ARP request
*             |<-----------|----------->|             ARP request
*             |            |<-----------|             ARP reply
*             |<-----------|            |             ARP reply
*             |----------->|            |             Data
*             |            |----------->|             Data
*             |            |<-----------|-----------> PATH_UPDATE (no broadcast was sent)
*             |<-----------|----------->|             PATH_UPDATE
* <-----------|----------->|            |             PATH_UPDATE
*             |            |<-----------|-----------> ARP request
*             |<-----------|----------->|             ARP request
* <-----------|----------->|            |             ARP request
*             |----------->|            |             ARP reply
*             |            |----------->|             ARP reply
*             |            |<-----------|             Data
*             |<-----------|            |             Data
*             |............|............|
*             After five seconds data is transmitted again as
*             broadcast, and PATH_UPDATE is sent
* 

Definition at line 63 of file flame-regression.h.

Constructor & Destructor Documentation

◆ FlameRegressionTest()

FlameRegressionTest::FlameRegressionTest ( )

Definition at line 43 of file flame-regression.cc.

◆ ~FlameRegressionTest()

FlameRegressionTest::~FlameRegressionTest ( )
override

Definition at line 51 of file flame-regression.cc.

References m_nodes.

Member Function Documentation

◆ CheckResults()

void FlameRegressionTest::CheckResults ( )

Check results function.

Definition at line 161 of file flame-regression.cc.

References NS_PCAP_TEST_EXPECT_EQ, and PREFIX.

Referenced by DoRun().

+ Here is the caller graph for this function:

◆ CreateDevices()

◆ CreateNodes()

void FlameRegressionTest::CreateNodes ( )
private

Create nodes function.

Definition at line 75 of file flame-regression.cc.

References ns3::NodeContainer::Create(), and m_nodes.

Referenced by DoRun().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ DoRun()

void FlameRegressionTest::DoRun ( )
overridevirtual

Implementation to actually run this TestCase.

Subclasses should override this method to conduct their tests.

Implements ns3::TestCase.

Definition at line 57 of file flame-regression.cc.

References CheckResults(), CreateDevices(), CreateNodes(), ns3::Simulator::Destroy(), InstallApplications(), m_nodes, m_time, ns3::Simulator::Run(), ns3::RngSeedManager::SetRun(), ns3::RngSeedManager::SetSeed(), and ns3::Simulator::Stop().

+ Here is the call graph for this function:

◆ HandleReadClient()

void FlameRegressionTest::HandleReadClient ( Ptr< Socket socket)
private

Handle a packet reception.

This function is called by lower layers.

Parameters
socketthe socket the packet was received to.

Definition at line 199 of file flame-regression.cc.

Referenced by InstallApplications().

+ Here is the caller graph for this function:

◆ HandleReadServer()

void FlameRegressionTest::HandleReadServer ( Ptr< Socket socket)
private

Handle a packet reception.

This function is called by lower layers.

Parameters
socketthe socket the packet was received to.

Definition at line 185 of file flame-regression.cc.

Referenced by InstallApplications().

+ Here is the caller graph for this function:

◆ InstallApplications()

void FlameRegressionTest::InstallApplications ( )
private

Install application function.

Definition at line 139 of file flame-regression.cc.

References ns3::Socket::Bind(), ns3::Socket::Connect(), ns3::Socket::CreateSocket(), ns3::NodeContainer::Get(), ns3::Ipv4InterfaceContainer::GetAddress(), ns3::Ipv4Address::GetAny(), ns3::Node::GetId(), ns3::Socket::GetNode(), HandleReadClient(), HandleReadServer(), ns3::TypeId::LookupByName(), m_clientSocket, m_interfaces, m_nodes, m_serverSocket, ns3::MakeCallback(), ns3::Simulator::ScheduleWithContext(), ns3::Seconds(), SendData(), and ns3::Socket::SetRecvCallback().

Referenced by DoRun().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ SendData()

void FlameRegressionTest::SendData ( Ptr< Socket socket)
private

Send data.

Parameters
socketthe sending socket

Definition at line 170 of file flame-regression.cc.

References m_sentPktsCounter, m_time, ns3::Simulator::Now(), ns3::Simulator::ScheduleWithContext(), ns3::Seconds(), and SendData().

Referenced by InstallApplications(), and SendData().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

Member Data Documentation

◆ m_clientSocket

Ptr<Socket> FlameRegressionTest::m_clientSocket
private

Client-side socket.

Definition at line 91 of file flame-regression.h.

Referenced by InstallApplications().

◆ m_interfaces

Ipv4InterfaceContainer FlameRegressionTest::m_interfaces
private

Needed to install applications.

Definition at line 79 of file flame-regression.h.

Referenced by CreateDevices(), and InstallApplications().

◆ m_nodes

NodeContainer* FlameRegressionTest::m_nodes
private
Internal: It is important to have pointers here

Definition at line 75 of file flame-regression.h.

Referenced by ~FlameRegressionTest(), CreateDevices(), CreateNodes(), DoRun(), and InstallApplications().

◆ m_sentPktsCounter

uint32_t FlameRegressionTest::m_sentPktsCounter
private

sent packets counter

Definition at line 94 of file flame-regression.h.

Referenced by SendData().

◆ m_serverSocket

Ptr<Socket> FlameRegressionTest::m_serverSocket
private

Server-side socket.

Definition at line 89 of file flame-regression.h.

Referenced by InstallApplications().

◆ m_time

Time FlameRegressionTest::m_time
private

Simulation time.

Definition at line 77 of file flame-regression.h.

Referenced by DoRun(), and SendData().


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