A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
hwmp-proactive-regression.cc
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2009 IITP RAS
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Authors: Kirill Andreev <andreev@iitp.ru>
19  */
20 
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"
37 #include <sstream>
38 #include "hwmp-proactive-regression.h"
39 
40 using namespace ns3;
41 
43 const char * const PREFIX = "hwmp-proactive-regression-test";
44 
45 
46 HwmpProactiveRegressionTest::HwmpProactiveRegressionTest () : TestCase ("HWMP proactive regression test"),
47  m_nodes (0),
48  m_time (Seconds (5))
49 {
50 }
51 
52 HwmpProactiveRegressionTest::~HwmpProactiveRegressionTest ()
53 {
54  delete m_nodes;
55 }
56 void
58 {
61  CreateNodes ();
62  CreateDevices ();
63  InstallApplications ();
64 
65  Simulator::Stop (m_time);
66  Simulator::Run ();
68 
69  CheckResults ();
70 
71  delete m_nodes, m_nodes = 0;
72 }
73 void
74 HwmpProactiveRegressionTest::CreateNodes ()
75 {
76  m_nodes = new NodeContainer;
77  m_nodes->Create (5);
78  MobilityHelper mobility;
79  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
80  "MinX", DoubleValue (0.0),
81  "MinY", DoubleValue (0.0),
82  "DeltaX", DoubleValue (100),
83  "DeltaY", DoubleValue (0),
84  "GridWidth", UintegerValue (5),
85  "LayoutType", StringValue ("RowFirst"));
86  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
87  mobility.Install (*m_nodes);
88 }
89 void
90 HwmpProactiveRegressionTest::InstallApplications ()
91 {
92  UdpEchoServerHelper echoServer (9);
93  ApplicationContainer serverApps = echoServer.Install (m_nodes->Get (0));
94  serverApps.Start (Seconds (0.0));
95  serverApps.Stop (m_time);
96  UdpEchoClientHelper echoClient (m_interfaces.GetAddress (0), 9);
97  echoClient.SetAttribute ("MaxPackets", UintegerValue (300));
98  echoClient.SetAttribute ("Interval", TimeValue (Seconds (0.5)));
99  echoClient.SetAttribute ("PacketSize", UintegerValue (100));
100  ApplicationContainer clientApps = echoClient.Install (m_nodes->Get (4));
101  clientApps.Start (Seconds (2.5));
102  clientApps.Stop (m_time);
103 }
104 void
105 HwmpProactiveRegressionTest::CreateDevices ()
106 {
107  int64_t streamsUsed = 0;
108  // 1. setup WiFi
110  // This test suite output was originally based on YansErrorRateModel
111  wifiPhy.SetErrorRateModel ("ns3::YansErrorRateModel");
113  Ptr<YansWifiChannel> chan = wifiChannel.Create ();
114  wifiPhy.SetChannel (chan);
115  // 2. setup mesh
117  mesh.SetStackInstaller ("ns3::Dot11sStack", "Root", Mac48AddressValue (Mac48Address ("00:00:00:00:00:0d")));
118  mesh.SetMacType ("RandomStart", TimeValue (Seconds (0.1)));
119  mesh.SetNumberOfInterfaces (1);
120  NetDeviceContainer meshDevices = mesh.Install (wifiPhy, *m_nodes);
121  // Five devices, 4 streams per device
122  streamsUsed += mesh.AssignStreams (meshDevices, streamsUsed);
123  NS_TEST_ASSERT_MSG_EQ (streamsUsed, (meshDevices.GetN () * 4), "Stream mismatch");
124  // No streams used here, by default
125  streamsUsed += wifiChannel.AssignStreams (chan, streamsUsed);
126  NS_TEST_ASSERT_MSG_EQ (streamsUsed, (meshDevices.GetN () * 4), "Stream mismatch");
127 
128  // 3. setup TCP/IP
129  InternetStackHelper internetStack;
130  internetStack.Install (*m_nodes);
131  Ipv4AddressHelper address;
132  address.SetBase ("10.1.1.0", "255.255.255.0");
133  m_interfaces = address.Assign (meshDevices);
134  // 4. write PCAP if needed
135  wifiPhy.EnablePcapAll (CreateTempDirFilename (PREFIX));
136 }
137 
138 void
139 HwmpProactiveRegressionTest::CheckResults ()
140 {
141  for (int i = 0; i < 5; ++i)
142  {
143  NS_PCAP_TEST_EXPECT_EQ (PREFIX << "-" << i << "-1.pcap");
144  }
145 }
146 
holds a vector of ns3::Application pointers.
smart pointer class similar to boost::intrusive_ptr
Definition: ptr.h:59
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
Definition: string.h:19
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 ...
static void Run(void)
Definition: simulator.cc:157
aggregate IP/TCP/UDP functionality to existing Nodes.
static YansWifiPhyHelper Default(void)
encapsulates test code
Definition: test.h:834
void SetNumberOfInterfaces(uint32_t nInterfaces)
Set a number of interfaces in a mesh network.
Definition: mesh-helper.cc:74
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
Definition: nstime.h:700
Hold an unsigned integer type.
Definition: uinteger.h:46
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())
Definition: mesh-helper.cc:123
static void Destroy(void)
Definition: simulator.cc:121
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
an EUI-48 address
Definition: mac48-address.h:41
manage and create wifi channel objects for the yans model.
int64_t AssignStreams(NetDeviceContainer c, int64_t stream)
Definition: mesh-helper.cc:212
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())
Definition: mesh-helper.cc:46
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.
Definition: nstime.h:586
NetDeviceContainer Install(const WifiPhyHelper &phyHelper, NodeContainer c) const
Install 802.11s mesh device & protocols on given node list.
Definition: mesh-helper.cc:79
hold objects of type ns3::Mac48Address
static void Stop(void)
Definition: simulator.cc:164
static MeshHelper Default()
Set the helper to the default values for the MAC type, remote station manager and channel policy...
Definition: mesh-helper.cc:113
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.
Definition: mesh-helper.h:38
virtual void DoRun()
Implementation to actually run this test case.
void SetPositionAllocator(Ptr< PositionAllocator > allocator)
Hold an floating point type.
Definition: double.h:41
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.