A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
hwmp-target-flags-regression.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2009 IITP RAS
3 *
4 * SPDX-License-Identifier: GPL-2.0-only
5 *
6 * Authors: Kirill Andreev <andreev@iitp.ru>
7 */
8
10
11#include "ns3/abort.h"
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/udp-echo-helper.h"
24#include "ns3/uinteger.h"
25#include "ns3/yans-wifi-helper.h"
26
27#include <sstream>
28
29using namespace ns3;
30
31/// Unique PCAP file name prefix
32const char* const PREFIX = "hwmp-target-flags-regression-test";
33
35 : TestCase("HWMP target flags regression test"),
36 m_nodes(nullptr),
37 m_time(Seconds(5)),
41{
42}
43
48
49void
66
67void
69{
71 m_nodes->Create(4);
72 MobilityHelper mobility;
73 mobility.SetPositionAllocator("ns3::GridPositionAllocator",
74 "MinX",
75 DoubleValue(0.0),
76 "MinY",
77 DoubleValue(0.0),
78 "DeltaX",
79 DoubleValue(100),
80 "DeltaY",
81 DoubleValue(0),
82 "GridWidth",
84 "LayoutType",
85 StringValue("RowFirst"));
86 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
87 mobility.Install(*m_nodes);
88}
89
90void
92{
93 // server socket A
95 Socket::CreateSocket(m_nodes->Get(0), TypeId::LookupByName("ns3::UdpSocketFactory"));
98
99 // server socket B
101 Socket::CreateSocket(m_nodes->Get(3), TypeId::LookupByName("ns3::UdpSocketFactory"));
104
105 // client socket A
107 Socket::CreateSocket(m_nodes->Get(1), TypeId::LookupByName("ns3::UdpSocketFactory"));
108 m_clientSocketA->Bind();
109 m_clientSocketA->Connect(InetSocketAddress(m_interfaces.GetAddress(0), 9));
112 Seconds(2.2),
114 this,
116
117 // client socket B
119 Socket::CreateSocket(m_nodes->Get(2), TypeId::LookupByName("ns3::UdpSocketFactory"));
120 m_clientSocketB->Bind();
121 m_clientSocketB->Connect(InetSocketAddress(m_interfaces.GetAddress(0), 9));
124 Seconds(2),
126 this,
128
129 // client socket C
131 Socket::CreateSocket(m_nodes->Get(0), TypeId::LookupByName("ns3::UdpSocketFactory"));
132 m_clientSocketB->Bind();
133 m_clientSocketB->Connect(InetSocketAddress(m_interfaces.GetAddress(3), 10));
136 Seconds(2.4),
138 this,
140}
141
142void
144{
145 int64_t streamsUsed = 0;
146 int64_t streamNumber = 0;
147 int64_t streamIncrement = 1000;
148 // 1. setup WiFi
149 YansWifiPhyHelper wifiPhy;
150 // This test suite output was originally based on YansErrorRateModel
151 wifiPhy.SetErrorRateModel("ns3::YansErrorRateModel");
153 Ptr<YansWifiChannel> chan = wifiChannel.Create();
154 wifiPhy.SetChannel(chan);
155 // This scenario setup predates the preamble detection model
157
158 // 2. setup mesh
160 mesh.SetStackInstaller("ns3::Dot11sStack");
161 mesh.SetMacType("RandomStart", TimeValue(Seconds(0.1)));
162 mesh.SetNumberOfInterfaces(1);
163 NetDeviceContainer meshDevices = mesh.Install(wifiPhy, *m_nodes);
164 // Four devices, ten streams per mac
165 streamsUsed = mesh.AssignStreams(meshDevices, streamNumber);
166 streamNumber += streamIncrement;
167 NS_TEST_ASSERT_MSG_EQ(streamsUsed, (meshDevices.GetN() * 10), "Stream assignment mismatch");
168 streamsUsed = wifiChannel.AssignStreams(chan, streamNumber);
169 streamNumber += streamIncrement;
170 NS_TEST_ASSERT_MSG_EQ(streamsUsed, 0, "No stream assignments expected for WifiChannel");
171
172 // 3. setup TCP/IP
173 InternetStackHelper internetStack;
174 internetStack.SetIpv6StackInstall(false);
175 internetStack.Install(*m_nodes);
176 internetStack.AssignStreams(*m_nodes, streamNumber);
177 Ipv4AddressHelper address;
178 address.SetBase("10.1.1.0", "255.255.255.0");
179 m_interfaces = address.Assign(meshDevices);
180 // 4. write PCAP if needed
182}
183
184void
186{
187 for (int i = 0; i < 4; ++i)
188 {
189 NS_PCAP_TEST_EXPECT_EQ(PREFIX << "-" << i << "-1.pcap");
190 }
191}
192
193void
195{
196 if ((Simulator::Now() < m_time) && (m_sentPktsCounterA < 300))
197 {
198 socket->Send(Create<Packet>(100));
200 Simulator::ScheduleWithContext(socket->GetNode()->GetId(),
201 Seconds(1),
203 this,
204 socket);
205 }
206}
207
208void
210{
211 if ((Simulator::Now() < m_time) && (m_sentPktsCounterA < 300))
212 {
213 socket->Send(Create<Packet>(100));
215 Simulator::ScheduleWithContext(socket->GetNode()->GetId(),
216 Seconds(1),
218 this,
219 socket);
220 }
221}
222
223void
225{
226 if ((Simulator::Now() < m_time) && (m_sentPktsCounterA < 300))
227 {
228 socket->Send(Create<Packet>(100));
230 Simulator::ScheduleWithContext(socket->GetNode()->GetId(),
231 Seconds(1),
233 this,
234 socket);
235 }
236}
237
238void
240{
241 Ptr<Packet> packet;
242 Address from;
243 while ((packet = socket->RecvFrom(from)))
244 {
245 packet->RemoveAllPacketTags();
246 packet->RemoveAllByteTags();
247
248 socket->SendTo(packet, 0, from);
249 }
250}
251
252void
254{
255 Ptr<Packet> packet;
256 Address from;
257 while ((packet = socket->RecvFrom(from)))
258 {
259 }
260}
void SendDataA(Ptr< Socket > socket)
Send data A.
void HandleReadClient(Ptr< Socket > socket)
Handle a packet reception.
void DoRun() override
Implementation to actually run this TestCase.
Ptr< Socket > m_serverSocketA
Server-side socket.
void CreateDevices()
Create devices function.
void SendDataC(Ptr< Socket > socket)
Send data C.
uint32_t m_sentPktsCounterA
sent packets counter A
void CheckResults()
Check results function.
Ptr< Socket > m_serverSocketB
Server-side socket.
void SendDataB(Ptr< Socket > socket)
Send data B.
uint32_t m_sentPktsCounterC
sent packets counter C
Ptr< Socket > m_clientSocketA
Client-side socket.
void HandleReadServer(Ptr< Socket > socket)
Handle a packet reception.
void InstallApplications()
Install application function.
Ipv4InterfaceContainer m_interfaces
interfaces
void CreateNodes()
Create nodes function.
uint32_t m_sentPktsCounterB
sent packets counter B
Ptr< Socket > m_clientSocketB
Client-side socket.
a polymophic address class
Definition address.h:114
This class can be used to hold variables of floating point type such as 'double' or 'float'.
Definition double.h:31
an Inet address class
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...
void SetIpv6StackInstall(bool enable)
Enable/disable IPv6 stack install.
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.
Definition mesh-helper.h:33
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.
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.
Definition ptr.h:70
static void SetRun(uint64_t run)
Set the run number of simulation.
static void SetSeed(uint32_t seed)
Set the seed.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
Definition simulator.cc:125
static void ScheduleWithContext(uint32_t context, const Time &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
Definition simulator.h:597
static Time Now()
Return the current simulation virtual time.
Definition simulator.cc:191
static void Run()
Run the simulation.
Definition simulator.cc:161
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Definition simulator.cc:169
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...
Definition socket.cc:61
Hold variables of type string.
Definition string.h:45
std::string CreateTempDirFilename(std::string filename)
Construct the full path to a file in a temporary directory.
Definition test.cc:436
TestCase(const TestCase &)=delete
Caller graph was not generated because of its size.
AttributeValue implementation for Time.
Definition nstime.h:1375
static TypeId LookupByName(std::string name)
Get a TypeId by name.
Definition type-id.cc:870
Hold an unsigned integer type.
Definition uinteger.h:34
void DisablePreambleDetectionModel()
Disable the preamble detection model on all links.
void SetErrorRateModel(std::string type, Args &&... args)
Helper function used to set the error rate model.
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)
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...
Definition callback.h:690
Ptr< T > Create(Ts &&... args)
Create class instances by constructors with varying numbers of arguments and return them by Ptr.
Definition ptr.h:454
#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:133
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition nstime.h:1273
const char *const PREFIX
Unique PCAP file name prefix.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
#define NS_PCAP_TEST_EXPECT_EQ(filename)
Test that a pair of reference/new pcap files are equal.
Definition pcap-test.h:28