12#include "ns3/double.h" 
   13#include "ns3/internet-stack-helper.h" 
   14#include "ns3/ipv4-address-helper.h" 
   15#include "ns3/mesh-helper.h" 
   16#include "ns3/mobility-helper.h" 
   17#include "ns3/mobility-model.h" 
   18#include "ns3/pcap-test.h" 
   19#include "ns3/random-variable-stream.h" 
   20#include "ns3/rng-seed-manager.h" 
   21#include "ns3/simulator.h" 
   22#include "ns3/string.h" 
   23#include "ns3/uinteger.h" 
   24#include "ns3/yans-wifi-helper.h" 
   31const char* 
const PREFIX = 
"hwmp-simplest-regression-test";
 
   34    : 
TestCase(
"Simplest HWMP regression test"),
 
 
   70    mobility.SetPositionAllocator(
"ns3::GridPositionAllocator",
 
   83    mobility.SetMobilityModel(
"ns3::ConstantPositionMobilityModel");
 
 
   97    model->SetPosition(Vector(9000, 0, 0));
 
 
  127    int64_t streamsUsed = 0;
 
  151    address.SetBase(
"10.1.1.0", 
"255.255.255.0");
 
 
  160    for (
int i = 0; i < 2; ++i)
 
 
  186    while ((packet = socket->RecvFrom(from)))
 
  188        packet->RemoveAllPacketTags();
 
  189        packet->RemoveAllByteTags();
 
  191        socket->SendTo(packet, 0, from);
 
 
  200    while ((packet = socket->RecvFrom(from)))
 
 
void HandleReadClient(Ptr< Socket > socket)
Handle a packet reception.
void DoRun() override
Implementation to actually run this TestCase.
Ipv4InterfaceContainer m_interfaces
interfaces
void ResetPosition()
Reset position.
void CheckResults()
Check results function.
void HandleReadServer(Ptr< Socket > socket)
Handle a packet reception.
~HwmpSimplestRegressionTest() override
void CreateDevices()
Create devices function.
Time m_time
Simulation time.
Ptr< Socket > m_serverSocket
Server-side socket.
void CreateNodes()
Create nodes function.
void InstallApplications()
Install application function.
void SendData(Ptr< Socket > socket)
Send data.
uint32_t m_sentPktsCounter
sent packets counter
Ptr< Socket > m_clientSocket
Client-side socket.
HwmpSimplestRegressionTest()
a polymophic address class
This class can be used to hold variables of floating point type such as 'double' or 'float'.
aggregate IP/TCP/UDP functionality to existing Nodes.
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
int64_t AssignStreams(NodeContainer c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
static Ipv4Address GetAny()
Helper to create IEEE 802.11s mesh networks.
void SetStackInstaller(std::string type, Ts &&... args)
Set the MeshStack type to use.
int64_t AssignStreams(NetDeviceContainer c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
static MeshHelper Default()
Set the helper to the default values for the MAC type, remote station manager and channel policy.
void SetMacType(Ts &&... args)
Set the Mac Attributes.
NetDeviceContainer Install(const WifiPhyHelper &phyHelper, NodeContainer c) const
Install 802.11s mesh device & protocols on given node list.
void SetNumberOfInterfaces(uint32_t nInterfaces)
Set a number of interfaces in a mesh network.
Helper class used to assign positions and mobility models to nodes.
Keep track of the current position and velocity of an object.
holds a vector of ns3::NetDevice pointers
uint32_t GetN() const
Get the number of Ptr<NetDevice> stored in this container.
keep track of a set of node pointers.
void EnablePcapAll(std::string prefix, bool promiscuous=false)
Enable pcap output on each device (which is of the appropriate type) in the set of all nodes created ...
Smart pointer class similar to boost::intrusive_ptr.
static void SetRun(uint64_t run)
Set the run number of simulation.
static void SetSeed(uint32_t seed)
Set the seed.
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void ScheduleWithContext(uint32_t context, const Time &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
static Time Now()
Return the current simulation virtual time.
static void Run()
Run the simulation.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
static Ptr< Socket > CreateSocket(Ptr< Node > node, TypeId tid)
This method wraps the creation of sockets that is performed on a given node by a SocketFactory specif...
Hold variables of type string.
std::string CreateTempDirFilename(std::string filename)
Construct the full path to a file in a temporary directory.
TestCase(const TestCase &)=delete
AttributeValue implementation for Time.
static TypeId LookupByName(std::string name)
Get a TypeId by name.
Hold an unsigned integer type.
manage and create wifi channel objects for the YANS model.
int64_t AssignStreams(Ptr< YansWifiChannel > c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by the channel.
static YansWifiChannelHelper Default()
Create a channel helper in a default working state.
Ptr< YansWifiChannel > Create() const
Make it easy to create and manage PHY objects for the YANS model.
void SetChannel(Ptr< YansWifiChannel > channel)
Ptr< T > Create(Ts &&... args)
Create class instances by constructors with varying numbers of arguments and return them by Ptr.
#define NS_TEST_ASSERT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report and abort if not.
Time Seconds(double value)
Construct a Time in the indicated unit.
const char *const PREFIX
Unique PCAP file name prefix.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Callback< R, Args... > MakeCallback(R(T::*memPtr)(Args...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
#define NS_PCAP_TEST_EXPECT_EQ(filename)
Test that a pair of reference/new pcap files are equal.