6#include "ns3/brite-module.h"
7#include "ns3/core-module.h"
8#include "ns3/internet-module.h"
9#include "ns3/network-module.h"
10#include "ns3/on-off-helper.h"
11#include "ns3/packet-sink-helper.h"
12#include "ns3/packet-sink.h"
13#include "ns3/point-to-point-module.h"
14#include "ns3/random-variable-stream.h"
38 void DoRun()
override;
42 :
TestCase(
"Test that two brite topologies created with same seed value produce same graph "
43 "(not an exact test)")
54 std::string confFile =
"src/brite/test/test.conf";
71 int numAsA = bthA.
GetNAs();
72 int numAsB = bthB.
GetNAs();
79 "Total number of nodes for each topology should be equal");
82 "Total number of edges for each topology should be equal");
84 for (
unsigned int i = 0; i < bthA.
GetNAs(); ++i)
88 "Total number of leaf nodes different for AS " << i);
106 void DoRun()
override;
110 :
TestCase(
"Test that packets can be send across a BRITE topology using UDP")
121 std::string confFile =
"src/brite/test/test.conf";
128 address.SetBase(
"10.0.0.0",
"255.255.255.0");
130 bth.BuildBriteTopology(stack);
131 bth.AssignIpv4Addresses(address);
137 stack.Install(source);
140 int numNodesInAsZero = bth.GetNNodesForAs(0);
141 source.
Add(bth.GetNodeForAs(0, numNodesInAsZero - 1));
147 int numNodesInAsOne = bth.GetNNodesForAs(1);
148 sink.Add(bth.GetNodeForAs(1, numNodesInAsOne - 1));
150 p2p.SetDeviceAttribute(
"DataRate",
StringValue(
"5Mbps"));
151 p2p.SetChannelAttribute(
"Delay",
StringValue(
"2ms"));
156 p2pSourceDevices = p2p.Install(source);
157 p2pSinkDevices = p2p.Install(
sink);
159 address.SetBase(
"10.1.0.0",
"255.255.0.0");
161 sourceInterfaces = address.Assign(p2pSourceDevices);
163 address.SetBase(
"10.2.0.0",
"255.255.0.0");
165 sinkInterfaces = address.Assign(p2pSinkDevices);
static BriteTestSuite g_briteTestSuite
Static variable for test initialization.
BRITE topology function Test.
void DoRun() override
Implementation to actually run this TestCase.
~BriteTopologyFunctionTestCase() override
BriteTopologyFunctionTestCase()
BRITE topology structure Test.
void DoRun() override
Implementation to actually run this TestCase.
BriteTopologyStructureTestCase()
~BriteTopologyStructureTestCase() override
a polymophic address class
holds a vector of ns3::Application pointers.
void Start(Time start) const
Start all of the Applications in this container at the start time given as a parameter.
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
void Stop(Time stop) const
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
ApplicationContainer Install(NodeContainer c)
Install an application on each node of the input container configured with all the attributes set wit...
void SetAttribute(const std::string &name, const AttributeValue &value)
Helper function used to set the underlying application attributes.
Interface with BRITE, the Boston university Representative Internet Topology gEnerator.
void AssignStreams(int64_t streamNumber)
Assigns stream number to UniformRandomVariable used to generate brite seed file.
uint32_t GetNAs() const
Returns the number of AS created in the topology.
uint32_t GetNNodesTopology() const
Returns the number of nodes created within the topology.
void BuildBriteTopology(InternetStackHelper &stack)
Create NS3 topology using information generated from BRITE.
uint32_t GetNLeafNodesForAs(uint32_t asNum)
Returns the number of router leaf nodes for a given AS.
uint32_t GetNEdgesTopology() const
Returns the number of edges created within the topology.
Class for representing data rates.
AttributeValue implementation for DataRate.
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
static Ipv4Address GetAny()
static void PopulateRoutingTables()
Build a routing database and initialize the routing tables of the nodes in the simulation.
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
holds a vector of ns3::NetDevice pointers
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 Add(const NodeContainer &nc)
Append the contents of another NodeContainer to the end of this container.
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index.
A helper to make it easier to instantiate an ns3::OnOffApplication on a set of nodes.
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes.
Build a set of PointToPointNetDevice objects.
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().
static void Run()
Run the simulation.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Hold variables of type string.
void AddTestCase(TestCase *testCase, Duration duration=Duration::QUICK)
Add an individual child TestCase to this test suite.
static constexpr auto UNIT
#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.
Time Seconds(double value)
Construct a Time in the indicated unit.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Ptr< T1 > DynamicCast(const Ptr< T2 > &p)
Cast a Ptr.
Ptr< PacketSink > sink
Pointer to the packet sink application.