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);
146 Simulator::ScheduleWithContext(socket->
GetNode()->
GetId(),
158 Simulator::ScheduleWithContext(socket->
GetNode()->
GetId(),
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));
293 Simulator::Schedule(
Seconds(5), &Ipv4::SetDown,
ipv4, ifIndex);
297 ifIndex = ipv6->GetInterfaceForDevice(dAdC.
Get(0));
298 Simulator::Schedule(
Seconds(5), &Ipv6::SetDown, ipv6, ifIndex);
300 Ipv4NixVectorHelper::PrintRoutingTableAllAt(
Seconds(7), cacheStreamv4);
301 Ipv6NixVectorHelper::PrintRoutingTableAllAt(
Seconds(7), cacheStreamv6);
317 ifIndex =
ipv4->GetInterfaceForDevice(dBdC.
Get(1));
318 Simulator::Schedule(
Seconds(10), &Ipv4::SetDown,
ipv4, ifIndex);
322 ifIndex = ipv6->GetInterfaceForDevice(dBdC.
Get(1));
323 Simulator::Schedule(
Seconds(10), &Ipv6::SetDown, ipv6, ifIndex);
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"
393 Simulator::Destroy();
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.
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.
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).
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...
virtual uint32_t GetRxAvailable() const =0
Return number of bytes which can be returned from one or multiple calls to Recv.
void SetRecvCallback(Callback< void, Ptr< Socket >> receivedData)
Notify application when new data is available to be read.
virtual Ptr< Packet > Recv(uint32_t maxSize, uint32_t flags)=0
Read data from the socket.
virtual Ptr< Node > GetNode() const =0
Return the node this socket is associated with.
virtual int Bind(const Address &address)=0
Allocate a local endpoint for this socket.
virtual int SendTo(Ptr< Packet > p, uint32_t flags, const Address &toAddress)=0
Send data to a specified peer.
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.