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.