21 #include "ns3/mesh-helper.h"
22 #include "ns3/simulator.h"
23 #include "ns3/random-variable-stream.h"
24 #include "ns3/rng-seed-manager.h"
25 #include "ns3/mobility-helper.h"
26 #include "ns3/double.h"
27 #include "ns3/uinteger.h"
28 #include "ns3/string.h"
29 #include "ns3/yans-wifi-helper.h"
30 #include "ns3/internet-stack-helper.h"
31 #include "ns3/ipv4-interface-container.h"
32 #include "ns3/ipv4-address-helper.h"
33 #include "ns3/abort.h"
34 #include "ns3/udp-echo-helper.h"
35 #include "ns3/mobility-model.h"
36 #include "ns3/pcap-test.h"
38 #include "hwmp-proactive-regression.h"
43 const char *
const PREFIX =
"hwmp-proactive-regression-test";
46 HwmpProactiveRegressionTest::HwmpProactiveRegressionTest () :
TestCase (
"HWMP proactive regression test"),
52 HwmpProactiveRegressionTest::~HwmpProactiveRegressionTest ()
63 InstallApplications ();
71 delete m_nodes, m_nodes = 0;
74 HwmpProactiveRegressionTest::CreateNodes ()
90 HwmpProactiveRegressionTest::InstallApplications ()
95 serverApps.
Stop (m_time);
102 clientApps.
Stop (m_time);
105 HwmpProactiveRegressionTest::CreateDevices ()
107 int64_t streamsUsed = 0;
122 streamsUsed += mesh.
AssignStreams (meshDevices, streamsUsed);
123 NS_TEST_ASSERT_MSG_EQ (streamsUsed, (meshDevices.
GetN () * 4),
"Stream mismatch");
125 streamsUsed += wifiChannel.
AssignStreams (chan, streamsUsed);
126 NS_TEST_ASSERT_MSG_EQ (streamsUsed, (meshDevices.
GetN () * 4),
"Stream mismatch");
130 internetStack.
Install (*m_nodes);
132 address.
SetBase (
"10.1.1.0",
"255.255.255.0");
133 m_interfaces = address.
Assign (meshDevices);
139 HwmpProactiveRegressionTest::CheckResults ()
141 for (
int i = 0; i < 5; ++i)
143 NS_PCAP_TEST_EXPECT_EQ (PREFIX <<
"-" << i <<
"-1.pcap");
holds a vector of ns3::Application pointers.
smart pointer class similar to boost::intrusive_ptr
void SetErrorRateModel(std::string name, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
Ptr< YansWifiChannel > Create(void) const
hold variables of type string
Make it easy to create and manage PHY objects for the yans model.
static YansWifiChannelHelper Default(void)
create an application which sends a udp packet and waits for an echo of this packet ...
aggregate IP/TCP/UDP functionality to existing Nodes.
static YansWifiPhyHelper Default(void)
void SetNumberOfInterfaces(uint32_t nInterfaces)
Set a number of interfaces in a mesh network.
static void SetRun(uint64_t run)
Set the run number of simulation.
uint32_t GetN(void) const
Get the number of Ptr<NetDevice> stored in this container.
void SetChannel(Ptr< YansWifiChannel > channel)
Create a server application which waits for input udp packets and sends them back to the original sen...
void Install(Ptr< Node > node) const
"Layout" a single node according to the current position allocator type.
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 ...
hold objects of type ns3::Time
Hold an unsigned integer type.
holds a vector of ns3::NetDevice pointers
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter...
void SetMacType(std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
static void Destroy(void)
keep track of a set of node pointers.
void SetMobilityModel(std::string type, std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue())
void Install(std::string nodeName) const
manage and create wifi channel objects for the yans model.
int64_t AssignStreams(NetDeviceContainer c, int64_t stream)
void SetStackInstaller(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
static void SetSeed(uint32_t seed)
set the seed it will duplicate the seed value 6 times
Helper class used to assign positions and mobility models to nodes.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter...
Ipv4InterfaceContainer Assign(const NetDeviceContainer &c)
Assign IP addresses to the net devices specified in the container based on the current network prefix...
Time Seconds(double seconds)
create ns3::Time instances in units of seconds.
NetDeviceContainer Install(const WifiPhyHelper &phyHelper, NodeContainer c) const
Install 802.11s mesh device & protocols on given node list.
hold objects of type ns3::Mac48Address
static MeshHelper Default()
Set the helper to the default values for the MAC type, remote station manager and channel policy...
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
void SetAttribute(std::string name, const AttributeValue &value)
Helper to create IEEE 802.11s mesh networks.
virtual void DoRun()
Implementation to actually run this test case.
void SetPositionAllocator(Ptr< PositionAllocator > allocator)
Hold an floating point type.
int64_t AssignStreams(Ptr< YansWifiChannel > c, int64_t stream)
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.