20#include "ns3/icmpv4-l4-protocol.h"
21#include "ns3/icmpv6-l4-protocol.h"
22#include "ns3/internet-stack-helper.h"
23#include "ns3/ipv4-address-helper.h"
24#include "ns3/ipv4-l3-protocol.h"
25#include "ns3/ipv6-address-helper.h"
26#include "ns3/ipv6-l3-protocol.h"
27#include "ns3/nix-vector-helper.h"
28#include "ns3/simple-net-device-helper.h"
29#include "ns3/simulator.h"
30#include "ns3/socket-factory.h"
31#include "ns3/socket.h"
33#include "ns3/udp-l4-protocol.h"
34#include "ns3/udp-socket-factory.h"
100 void DoRun()
override;
113 :
TestCase(
"three router, two path test")
120 uint32_t availableData [[maybe_unused]] = socket->GetRxAvailable();
124 "availableData should be equal to the size of packet received.");
132 socket->SendTo(Create<Packet>(123), 0, realTo);
139 socket->SendTo(Create<Packet>(123), 0, realTo);
195 std::ostringstream stringStream1v4;
197 std::ostringstream stringStream1v6;
199 std::ostringstream stringStream2v4;
201 std::ostringstream stringStream2v6;
203 std::ostringstream stringStream3v4;
205 std::ostringstream stringStream3v6;
212 stack.SetRoutingHelper(ipv4NixRouting);
213 stack.SetRoutingHelper(ipv6NixRouting);
214 stack.Install(allNodes);
221 dSrcdA = devHelper.
Install(nSrcnA);
222 dAdB = devHelper.
Install(nAnB);
223 dBdC = devHelper.
Install(nBnC);
224 dCdDst = devHelper.
Install(nCnDst);
225 dAdC = devHelper.
Install(nAnC);
228 aSrcaAv4.
SetBase(
"10.1.0.0",
"255.255.255.0");
230 aAaBv4.
SetBase(
"10.1.1.0",
"255.255.255.0");
232 aBaCv4.
SetBase(
"10.1.2.0",
"255.255.255.0");
234 aCaDstv4.
SetBase(
"10.1.3.0",
"255.255.255.0");
236 aAaCv4.
SetBase(
"10.1.4.0",
"255.255.255.0");
263 Ptr<Socket> rxSocketv4 = rxSocketFactory->CreateSocket();
264 Ptr<Socket> rxSocketv6 = rxSocketFactory->CreateSocket();
275 Ptr<Socket> txSocket = txSocketFactory->CreateSocket();
276 txSocket->SetAllowBroadcast(
true);
292 int32_t ifIndex = ipv4->GetInterfaceForDevice(dAdC.
Get(0));
297 ifIndex = ipv6->GetInterfaceForDevice(dAdC.
Get(0));
300 Ipv4NixVectorHelper::PrintRoutingTableAllAt(
Seconds(7), cacheStreamv4);
301 Ipv6NixVectorHelper::PrintRoutingTableAllAt(
Seconds(7), cacheStreamv6);
317 ifIndex = ipv4->GetInterfaceForDevice(dBdC.
Get(1));
322 ifIndex = ipv6->GetInterfaceForDevice(dBdC.
Get(1));
338 "IPv4 and IPv6 Nix-Vector Routing should have received only 1 packet.");
341 const std::string p_nSrcnAnCnDstv4 =
342 "Time: +3s, Nix Routing\n"
343 "Route path from Node 0 to Node 4, Nix Vector: 01001 (5 bits left)\n"
344 "10.1.0.1 (Node 0) ----> 10.1.0.2 (Node 1)\n"
345 "10.1.4.1 (Node 1) ----> 10.1.4.2 (Node 3)\n"
346 "10.1.3.1 (Node 3) ----> 10.1.3.2 (Node 4)\n\n";
349 const std::string p_nSrcnAnCnDstv6 =
350 "Time: +3s, Nix Routing\n"
351 "Route path from Node 0 to Node 4, Nix Vector: 01001 (5 bits left)\n"
352 "2001::200:ff:fe00:1 (Node 0) ----> fe80::200:ff:fe00:2 (Node 1)\n"
353 "fe80::200:ff:fe00:9 (Node 1) ----> fe80::200:ff:fe00:a (Node 3)\n"
354 "fe80::200:ff:fe00:7 (Node 3) ----> 2001:3::200:ff:fe00:8 (Node 4)\n\n";
357 const std::string p_nSrcnAnBnCnDstv4 =
358 "Time: +9s, Nix Routing\n"
359 "Route path from Node 0 to Node 4, Nix Vector: 0111 (4 bits left)\n"
360 "10.1.0.1 (Node 0) ----> 10.1.0.2 (Node 1)\n"
361 "10.1.1.1 (Node 1) ----> 10.1.1.2 (Node 2)\n"
362 "10.1.2.1 (Node 2) ----> 10.1.2.2 (Node 3)\n"
363 "10.1.3.1 (Node 3) ----> 10.1.3.2 (Node 4)\n\n";
366 const std::string p_nSrcnAnBnCnDstv6 =
367 "Time: +9s, Nix Routing\n"
368 "Route path from Node 0 to Node 4, Nix Vector: 0111 (4 bits left)\n"
369 "2001::200:ff:fe00:1 (Node 0) ----> fe80::200:ff:fe00:2 (Node 1)\n"
370 "fe80::200:ff:fe00:3 (Node 1) ----> fe80::200:ff:fe00:4 (Node 2)\n"
371 "fe80::200:ff:fe00:5 (Node 2) ----> fe80::200:ff:fe00:6 (Node 3)\n"
372 "fe80::200:ff:fe00:7 (Node 3) ----> 2001:3::200:ff:fe00:8 (Node 4)\n\n";
375 const std::string emptyCaches =
"Node: 0, Time: +7s, Local time: +7s, Nix Routing\n"
378 "Node: 1, Time: +7s, Local time: +7s, Nix Routing\n"
381 "Node: 2, Time: +7s, Local time: +7s, Nix Routing\n"
384 "Node: 3, Time: +7s, Local time: +7s, Nix Routing\n"
387 "Node: 4, Time: +7s, Local time: +7s, Nix Routing\n"
The topology is of the form:
void DoSendDatav4(Ptr< Socket > socket, Ipv4Address to)
Send data immediately after being called.
void DoRun() override
Implementation to actually run this TestCase.
std::vector< uint32_t > m_receivedPacketSizes
Received packet sizes.
Ptr< Packet > m_receivedPacket
Received packet.
void ReceivePkt(Ptr< Socket > socket)
Receive data.
void DoSendDatav6(Ptr< Socket > socket, Ipv6Address to)
Send data immediately after being called.
void SendData(Time delay, Ptr< Socket > socket, Ipv4Address to)
Schedules the DoSendData () function to send the data.
IPv4 Nix-Vector Routing TestSuite.
NixVectorRoutingTestSuite()
a polymophic address class
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
void SetBase(Ipv4Address network, Ipv4Mask mask, Ipv4Address base="0.0.0.1")
Set the base network number, network mask and base address.
Ipv4InterfaceContainer Assign(const NetDeviceContainer &c)
Assign IP addresses to the net devices specified in the container based on the current network prefix...
Ipv4 addresses are stored in host order in this class.
Access to the IPv4 forwarding table, interfaces, and configuration.
virtual void SetDown(uint32_t interface)=0
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Ipv4Address GetAddress(uint32_t i, uint32_t j=0) const
Helper class to auto-assign global IPv6 unicast addresses.
void SetBase(Ipv6Address network, Ipv6Prefix prefix, Ipv6Address base=Ipv6Address("::1"))
Set the base network number, network prefix, and base interface ID.
Ipv6InterfaceContainer Assign(const NetDeviceContainer &c)
Allocate an Ipv6InterfaceContainer with auto-assigned addresses.
Describes an IPv6 address.
Access to the IPv6 forwarding table, interfaces, and configuration.
virtual void SetDown(uint32_t interface)=0
Set the interface into the "down" state.
Keep track of a set of IPv6 interfaces.
Ipv6Address GetAddress(uint32_t i, uint32_t j) const
Get the address for the specified index.
Describes an IPv6 prefix.
holds a vector of ns3::NetDevice pointers
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr<NetDevice> stored in this container at a given index.
Helper class that adds Nix-vector routing to nodes.
void PrintRoutingPathAt(Time printTime, Ptr< Node > source, IpAddress dest, Ptr< OutputStreamWrapper > stream, Time::Unit unit=Time::S)
prints the routing path for a source and destination at a particular time.
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.
Ptr< T > GetObject() const
Get a pointer to the requested aggregated Object.
uint32_t GetSize() const
Returns the the size in bytes of the packet (including the zero-filled initial payload).
Smart pointer class similar to boost::intrusive_ptr.
build a set of SimpleNetDevice objects
void SetNetDevicePointToPointMode(bool pointToPointMode)
SimpleNetDevice is Broadcast capable and ARP needing.
NetDeviceContainer Install(Ptr< Node > node) const
This method creates an ns3::SimpleChannel with the attributes configured by SimpleNetDeviceHelper::Se...
static EventId Schedule(const Time &delay, FUNC f, Ts &&... args)
Schedule an event to expire after delay.
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
static void ScheduleWithContext(uint32_t context, const Time &delay, FUNC f, Ts &&... args)
Schedule an event with the given context.
static void Run()
Run the simulation.
static void Stop()
Tell the Simulator the calling event should be the last one executed.
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
@ UNIT
This test suite implements a Unit Test.
Simulation virtual time values and global simulation resolution.
API to create UDP socket instances.
#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.
#define NS_TEST_EXPECT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report 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.
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...
static NixVectorRoutingTestSuite g_nixVectorRoutingTestSuite
Static variable for test initialization.