22 #include "ns3/simulator.h"    23 #include "ns3/random-variable-stream.h"    24 #include "ns3/rng-seed-manager.h"    25 #include "ns3/string.h"    26 #include "ns3/mobility-helper.h"    27 #include "ns3/double.h"    28 #include "ns3/uinteger.h"    29 #include "ns3/boolean.h"    30 #include "ns3/yans-wifi-helper.h"    31 #include "ns3/internet-stack-helper.h"    32 #include "ns3/ipv4-address-helper.h"    33 #include "ns3/abort.h"    34 #include "ns3/mobility-model.h"    35 #include "ns3/pcap-file.h"    36 #include "ns3/aodv-helper.h"    37 #include "ns3/v4ping-helper.h"    38 #include "ns3/config.h"    39 #include "ns3/inet-socket-address.h"    40 #include "ns3/data-rate.h"    41 #include "ns3/pcap-test.h"    50   : 
TestCase (
"Bug 772 UDP and TCP chain regression test"),
    72       socket->
Send (Create<Packet> (1000));
    87   RngSeedManager::SetSeed (12345);
    88   RngSeedManager::SetRun (7);
    98   Simulator::Destroy ();
   111   mobility.SetPositionAllocator (
"ns3::GridPositionAllocator",
   118   mobility.SetMobilityModel (
"ns3::ConstantPositionMobilityModel");
   125   int64_t streamsUsed = 0;
   128   wifiMac.
SetType (
"ns3::AdhocWifiMac");
   142   streamsUsed += 
wifi.AssignStreams (
devices, streamsUsed);
   145   streamsUsed += wifiChannel.
AssignStreams (chan, streamsUsed);
   161   address.SetBase (
"10.1.1.0", 
"255.255.255.0");
 const std::string m_proto
Socket factory TID. 
void Set(std::string name, const AttributeValue &v)
Simulation virtual time values and global simulation resolution. 
uint32_t GetId(void) const
holds a vector of std::pair of Ptr<Ipv4> and interface index. 
Hold variables of type string. 
virtual bool SetAllowBroadcast(bool allowBroadcast)=0
Configure whether broadcast datagram transmissions are allowed. 
Make it easy to create and manage PHY objects for the yans model. 
const uint32_t m_size
Chain size. 
void CheckResults()
Compare traces with reference ones. 
virtual int ShutdownSend(void)=0
aggregate IP/TCP/UDP functionality to existing Nodes. 
#define NS_TEST_EXPECT_MSG_EQ(actual, limit, msg)
Test that an actual and expected (limit) value are equal and report if not. 
helps to create WifiNetDevice objects 
Ptr< YansWifiChannel > Create(void) const
void CreateNodes()
Create test topology. 
void SendData(Ptr< Socket > socket)
Send data. 
virtual int Listen(void)=0
Listen for incoming connections. 
void SetChannel(Ptr< YansWifiChannel > channel)
Hold an unsigned integer type. 
#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. 
const Time m_time
Total simulation time. 
holds a vector of ns3::NetDevice pointers 
Callback< R > MakeCallback(R(T::*memPtr)(void), OBJ objPtr)
void SetRecvCallback(Callback< void, Ptr< Socket > >)
Notify application when new data is available to be read. 
virtual int Connect(const Address &address)=0
Initiate a connection to a remote host. 
virtual int Bind(const Address &address)=0
Allocate a local endpoint for this socket. 
Every class exported by the ns3 library is enclosed in the ns3 namespace. 
keep track of a set of node pointers. 
uint32_t m_receivedPackets
Received packet count. 
const uint16_t m_port
port number 
void CreateDevices()
Create devices, install TCP/IP stack and applications. 
manage and create wifi channel objects for the yans model. 
create MAC layers for a ns3::WifiNetDevice. 
Ptr< Socket > m_sendSocket
Transmitting socket. 
void SetErrorRateModel(std::string name, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue())
virtual void SetType(std::string type, std::string n0="", const AttributeValue &v0=EmptyAttributeValue(), std::string n1="", const AttributeValue &v1=EmptyAttributeValue(), std::string n2="", const AttributeValue &v2=EmptyAttributeValue(), std::string n3="", const AttributeValue &v3=EmptyAttributeValue(), std::string n4="", const AttributeValue &v4=EmptyAttributeValue(), std::string n5="", const AttributeValue &v5=EmptyAttributeValue(), std::string n6="", const AttributeValue &v6=EmptyAttributeValue(), std::string n7="", const AttributeValue &v7=EmptyAttributeValue(), std::string n8="", const AttributeValue &v8=EmptyAttributeValue(), std::string n9="", const AttributeValue &v9=EmptyAttributeValue(), std::string n10="", const AttributeValue &v10=EmptyAttributeValue())
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
Helper class used to assign positions and mobility models to nodes. 
int64_t AssignStreams(NodeContainer c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model...
virtual Ptr< Node > GetNode(void) const =0
Return the node this socket is associated with. 
Time Seconds(double value)
Construct a Time in the indicated unit. 
void SetDefault(std::string name, const AttributeValue &value)
int64_t AssignStreams(NodeContainer c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by this model...
Ptr< Socket > m_recvSocket
Receiving socket. 
Ptr< Node > Get(uint32_t i) const
Get the Ptr<Node> stored in this container at a given index. 
A helper class to make life easier while doing simple IPv4 address assignment in scripts. 
Time Now(void)
create an ns3::Time instance which contains the current simulation time. 
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer. 
Helper class that adds AODV routing to nodes. 
void HandleRead(Ptr< Socket > socket)
Receive data function. 
virtual int Send(Ptr< Packet > p, uint32_t flags)=0
Send data (or dummy data) to the remote host. 
This class can be used to hold variables of floating point type such as 'double' or 'float'...
void SetRoutingHelper(const Ipv4RoutingHelper &routing)
const double m_step
Chain step, meters. 
int64_t AssignStreams(Ptr< YansWifiChannel > c, int64_t stream)
Assign a fixed random variable stream number to the random variables used by the channel. 
Bug772ChainTest(const char *const prefix, const char *const proto, Time time, uint32_t size)
Create test case.