A Discrete-Event Network Simulator
QKDNetSim v2.0 (NS-3 v3.41) @ (+)
API
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
pmp-regression.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 IITP RAS
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation;
7  *
8  * This program is distributed in the hope that it will be useful,
9  * but WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11  * GNU General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License
14  * along with this program; if not, write to the Free Software
15  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16  *
17  * Authors: Pavel Boyko <boyko@iitp.ru>
18  */
19 #include "pmp-regression.h"
20 
21 #include "ns3/double.h"
22 #include "ns3/internet-stack-helper.h"
23 #include "ns3/mesh-helper.h"
24 #include "ns3/mobility-helper.h"
25 #include "ns3/mobility-model.h"
26 #include "ns3/pcap-file.h"
27 #include "ns3/pcap-test.h"
28 #include "ns3/random-variable-stream.h"
29 #include "ns3/rng-seed-manager.h"
30 #include "ns3/simulator.h"
31 #include "ns3/string.h"
32 #include "ns3/uinteger.h"
33 #include "ns3/yans-wifi-helper.h"
34 
35 #include <sstream>
36 
37 using namespace ns3;
38 
40 const char* const PREFIX = "pmp-regression-test";
41 
43  : TestCase("PMP regression test"),
44  m_nodes(nullptr),
45  m_time(Seconds(1))
46 {
47 }
48 
50 {
51  delete m_nodes;
52 }
53 
54 void
56 {
57  RngSeedManager::SetSeed(1);
58  RngSeedManager::SetRun(1);
59  CreateNodes();
60  CreateDevices();
61 
62  Simulator::Stop(m_time);
63  Simulator::Run();
64  Simulator::Destroy();
65 
66  CheckResults();
67 
68  delete m_nodes, m_nodes = nullptr;
69 }
70 
71 void
73 {
74  m_nodes = new NodeContainer;
75  m_nodes->Create(2);
77  mobility.SetPositionAllocator("ns3::GridPositionAllocator",
78  "MinX",
79  DoubleValue(0.0),
80  "MinY",
81  DoubleValue(0.0),
82  "DeltaX",
83  DoubleValue(1 /*meter*/),
84  "DeltaY",
85  DoubleValue(0),
86  "GridWidth",
87  UintegerValue(2),
88  "LayoutType",
89  StringValue("RowFirst"));
90  mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
91  mobility.Install(*m_nodes);
92 }
93 
94 void
96 {
97  int64_t streamsUsed = 0;
98  // 1. setup WiFi
99  YansWifiPhyHelper wifiPhy;
100  YansWifiChannelHelper wifiChannel = YansWifiChannelHelper::Default();
101  Ptr<YansWifiChannel> chan = wifiChannel.Create();
102  wifiPhy.SetChannel(chan);
103  // 2. setup mesh
104  MeshHelper mesh = MeshHelper::Default();
105  mesh.SetStackInstaller("ns3::Dot11sStack");
106  mesh.SetMacType("RandomStart", TimeValue(Seconds(0.1)));
107  mesh.SetNumberOfInterfaces(1);
108  NetDeviceContainer meshDevices = mesh.Install(wifiPhy, *m_nodes);
109  // Two devices, 10 streams per device (one for mac, one for phy,
110  // two for plugins, five for regular mac wifi DCF, and one for MeshPointDevice)
111  streamsUsed += mesh.AssignStreams(meshDevices, 0);
112  NS_TEST_ASSERT_MSG_EQ(streamsUsed, (meshDevices.GetN() * 10), "Stream assignment mismatch");
113  streamsUsed += wifiChannel.AssignStreams(chan, streamsUsed);
114  // 3. write PCAP if needed
116 }
117 
118 void
120 {
121  for (int i = 0; i < 2; ++i)
122  {
123  NS_PCAP_TEST_EXPECT_EQ(PREFIX << "-" << i << "-1.pcap");
124  }
125 }
void CreateDevices()
Create devices function.
void DoRun() override
Implementation to actually run this TestCase.
void CheckResults()
Check results function.
void CreateNodes()
Create nodes function.
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Definition: double.h:42
Helper to create IEEE 802.11s mesh networks.
Definition: mesh-helper.h:44
void SetStackInstaller(std::string type, Ts &&... args)
Set the MeshStack type to use.
Definition: mesh-helper.h:210
int64_t AssignStreams(NetDeviceContainer c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model.
Definition: mesh-helper.cc:178
void SetMacType(Ts &&... args)
Set the Mac Attributes.
Definition: mesh-helper.h:195
NetDeviceContainer Install(const WifiPhyHelper &phyHelper, NodeContainer c) const
Install 802.11s mesh device & protocols on given node list.
Definition: mesh-helper.cc:63
void SetNumberOfInterfaces(uint32_t nInterfaces)
Set a number of interfaces in a mesh network.
Definition: mesh-helper.cc:57
Helper class used to assign positions and mobility models to nodes.
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 Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
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.
Definition: ptr.h:77
Hold variables of type string.
Definition: string.h:56
encapsulates test code
Definition: test.h:1060
std::string CreateTempDirFilename(std::string filename)
Construct the full path to a file in a temporary directory.
Definition: test.cc:438
Hold an unsigned integer type.
Definition: uinteger.h:45
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.
Ptr< YansWifiChannel > Create() const
Make it easy to create and manage PHY objects for the YANS model.
void SetChannel(Ptr< YansWifiChannel > channel)
#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.
Definition: test.h:144
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition: nstime.h:1326
Every class exported by the ns3 library is enclosed in the ns3 namespace.
mobility
Definition: third.py:105
#define NS_PCAP_TEST_EXPECT_EQ(filename)
Test that a pair of reference/new pcap files are equal.
Definition: pcap-test.h:39
const char *const PREFIX
Unique PCAP file name prefix.
double m_time
Definition: qkd_etsi_014.cc:62