A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
pmp-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: Pavel Boyko <boyko@iitp.ru>
7 */
8#include "pmp-regression.h"
9
10#include "ns3/double.h"
11#include "ns3/internet-stack-helper.h"
12#include "ns3/mesh-helper.h"
13#include "ns3/mobility-helper.h"
14#include "ns3/mobility-model.h"
15#include "ns3/pcap-file.h"
16#include "ns3/pcap-test.h"
17#include "ns3/random-variable-stream.h"
18#include "ns3/rng-seed-manager.h"
19#include "ns3/simulator.h"
20#include "ns3/string.h"
21#include "ns3/uinteger.h"
22#include "ns3/yans-wifi-helper.h"
23
24#include <sstream>
25
26using namespace ns3;
27
28/// Unique PCAP file name prefix
29const char* const PREFIX = "pmp-regression-test";
30
32 : TestCase("PMP regression test"),
33 m_nodes(nullptr),
34 m_time(Seconds(1))
35{
36}
37
42
43void
59
60void
62{
64 m_nodes->Create(2);
65 MobilityHelper mobility;
66 mobility.SetPositionAllocator("ns3::GridPositionAllocator",
67 "MinX",
68 DoubleValue(0.0),
69 "MinY",
70 DoubleValue(0.0),
71 "DeltaX",
72 DoubleValue(1 /*meter*/),
73 "DeltaY",
74 DoubleValue(0),
75 "GridWidth",
77 "LayoutType",
78 StringValue("RowFirst"));
79 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
80 mobility.Install(*m_nodes);
81}
82
83void
85{
86 int64_t streamsUsed = 0;
87 // 1. setup WiFi
88 YansWifiPhyHelper wifiPhy;
90 Ptr<YansWifiChannel> chan = wifiChannel.Create();
91 wifiPhy.SetChannel(chan);
92 // 2. setup mesh
94 mesh.SetStackInstaller("ns3::Dot11sStack");
95 mesh.SetMacType("RandomStart", TimeValue(Seconds(0.1)));
97 NetDeviceContainer meshDevices = mesh.Install(wifiPhy, *m_nodes);
98 // Two devices, 10 streams per device (one for mac, one for phy,
99 // two for plugins, five for regular mac wifi DCF, and one for MeshPointDevice)
100 streamsUsed += mesh.AssignStreams(meshDevices, 0);
101 NS_TEST_ASSERT_MSG_EQ(streamsUsed, (meshDevices.GetN() * 10), "Stream assignment mismatch");
102 streamsUsed += wifiChannel.AssignStreams(chan, streamsUsed);
103 // 3. write PCAP if needed
105}
106
107void
109{
110 for (int i = 0; i < 2; ++i)
111 {
112 NS_PCAP_TEST_EXPECT_EQ(PREFIX << "-" << i << "-1.pcap");
113 }
114}
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:31
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 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.
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:131
static void Run()
Run the simulation.
Definition simulator.cc:167
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Definition simulator.cc:175
Hold variables of type string.
Definition string.h:45
encapsulates test code
Definition test.h:1050
std::string CreateTempDirFilename(std::string filename)
Construct the full path to a file in a temporary directory.
Definition test.cc:432
Hold an unsigned integer type.
Definition uinteger.h:34
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)
#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:134
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition nstime.h:1308
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
const char *const PREFIX
Unique PCAP file name prefix.