22 #include "ns3/abort.h"
24 #include "ns3/pcap-file.h"
25 #include "ns3/config.h"
26 #include "ns3/string.h"
27 #include "ns3/uinteger.h"
28 #include "ns3/data-rate.h"
29 #include "ns3/inet-socket-address.h"
30 #include "ns3/point-to-point-helper.h"
31 #include "ns3/internet-stack-helper.h"
32 #include "ns3/ipv4-global-routing-helper.h"
33 #include "ns3/ipv4-address-helper.h"
34 #include "ns3/packet-sink-helper.h"
35 #include "ns3/tcp-socket-factory.h"
36 #include "ns3/node-container.h"
37 #include "ns3/simulator.h"
38 #include "ns3/error-model.h"
39 #include "ns3/pointer.h"
41 #include "ns3/tcp-westwood.h"
42 #include "ns3/tcp-header.h"
85 virtual void DoSetup (
void);
86 virtual void DoRun (
void);
87 virtual void DoTeardown (
void);
117 void CwndTracer (uint32_t oldval, uint32_t newval);
137 :
TestCase (
"Check the operation of the TCP state machine for several cases"),
139 m_totalTxBytes (200000),
140 m_currentTxBytes (0),
144 m_needToClose (true),
145 m_tcpModel (
"ns3::TcpWestwood")
150 :
TestCase (
"Check the behaviour of TCP upon packet losses"),
151 m_testCase (testCase),
152 m_totalTxBytes (200000),
153 m_currentTxBytes (0),
157 m_needToClose (true),
158 m_tcpModel (tcpModel)
176 std::ostringstream oss;
189 "Wrong response vectors in directory: opening " <<
226 uint32_t (tMicroSeconds % 1000000),
236 uint32_t tsSec, tsUsec, inclLen, origLen, readLen;
237 m_pcapFile.
Read (expectedBuffer,
sizeof(expectedBuffer), tsSec, tsUsec, inclLen, origLen, readLen);
241 uint8_t *actual =
new uint8_t[readLen];
242 received->
CopyData (actual, readLen);
244 int result = memcmp (actual, expectedBuffer, readLen);
246 TcpHeader expectedHeader, receivedHeader;
247 Ptr<Packet> expected = Create<Packet> (expectedBuffer, readLen);
252 NS_LOG_DEBUG (
"Expected " << expectedHeader <<
" received: " << receivedHeader);
271 *(
m_osw->
GetStream ()) <<
"Moving cwnd from " << oldval <<
" to " << newval
273 <<
" seconds" << std::endl;
286 uint32_t toWrite = 1040 - dataOffset;
289 toWrite =
std::min (toWrite, txAvail);
296 std::clog <<
"Submitting " << toWrite
297 <<
" bytes to TCP socket" << std::endl;
299 int amountSent = localSocket->
Send (0, toWrite, 0);
307 std::clog <<
"Close socket at "
310 localSocket->
Close ();
322 std::clog <<
"Starting flow at time "
348 std::ostringstream tcpModel;
404 ipv4.
SetBase (
"10.1.3.0",
"255.255.255.0");
406 ipv4.
SetBase (
"10.1.2.0",
"255.255.255.0");
410 Ipv4GlobalRoutingHelper::PopulateRoutingTables ();
417 uint16_t servPort = 50000;
427 Ptr<Socket> localSocket = Socket::CreateSocket (s1r1.
Get (0), TcpSocketFactory::GetTypeId ());
428 localSocket->
Bind ();
439 (
"/NodeList/0/$ns3::TcpL4Protocol/SocketList/0/CongestionWindow",
445 std::list<uint32_t> sampleList;
453 sampleList.push_back (16);
456 sampleList.push_back (16);
457 sampleList.push_back (17);
460 sampleList.push_back (16);
461 sampleList.push_back (17);
462 sampleList.push_back (18);
465 sampleList.push_back (16);
466 sampleList.push_back (17);
467 sampleList.push_back (18);
468 sampleList.push_back (19);
476 pem->SetList (sampleList);
484 std::ostringstream oss;
492 std::ostringstream oss2;
504 Simulator::Stop (
Seconds (1000));
506 Simulator::Destroy ();
524 SetDataDir (
"src/test/ns3tcp/response-vectors");
525 Packet::EnablePrinting ();
Tests of TCP implementation loss behavior.
void CwndTracer(uint32_t oldval, uint32_t newval)
CWND trace.
virtual void DoSetup(void)
Implementation to do any local setup required for this TestCase.
uint32_t m_currentTxBytes
Current number of bytes sent.
void StartFlow(Ptr< Socket > localSocket, Ipv4Address servAddress, uint16_t servPort)
Start transmitting a TCP flow.
PcapFile m_pcapFile
The PCAP ffile.
bool m_writeVectors
True if response vectors have to be written (and not read).
uint32_t m_testCase
Testcase number.
Ptr< OutputStreamWrapper > m_osw
The output stream.
bool m_writeResults
True if write PCAP files.
bool m_writeLogging
True if write logging.
virtual void DoRun(void)
Implementation to actually run this TestCase.
uint32_t m_totalTxBytes
Total number of bytes to send.
virtual ~Ns3TcpLossTestCase()
void WriteUntilBufferFull(Ptr< Socket > localSocket, uint32_t txSpace)
Write to the socket until the buffer is full.
std::string m_pcapFilename
The PCAP filename.
void Ipv4L3Tx(std::string context, Ptr< const Packet > packet, Ptr< Ipv4 > ipv4, uint32_t interface)
Check that the transmitted packets are consitent with the trace.
virtual void DoTeardown(void)
Implementation to do any local setup required for this TestCase.
std::string m_tcpModel
The TCP model name.
bool m_needToClose
Check if the sending socket need to be closed.
TCP implementation loss behavior TestSuite.
holds a vector of ns3::Application pointers.
void Start(Time start)
Arrange for all of the Applications in this container to Start() at the Time given as a parameter.
void Stop(Time stop)
Arrange for all of the Applications in this container to Stop() at the Time given as a parameter.
void EnableAsciiAll(std::string prefix)
Enable ascii trace output on each device (which is of the appropriate type) in the set of all nodes c...
Manage ASCII trace files for device models.
Ptr< OutputStreamWrapper > CreateFileStream(std::string filename, std::ios::openmode filemode=std::ios::out)
Create and initialize an output stream object we'll use to write the traced bits.
AttributeValue implementation for Boolean.
Class for representing data rates.
AttributeValue implementation for DataRate.
Hold variables of type enum.
aggregate IP/TCP/UDP functionality to existing Nodes.
void InstallAll(void) const
Aggregate IPv4, IPv6, UDP, and TCP stacks to all nodes in the simulation.
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.
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
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr<NetDevice> stored in this container at a given index.
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(NodeContainer other)
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.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
std::ostream * GetStream(void)
Return a pointer to an ostream previously set in the wrapper.
uint32_t RemoveHeader(Header &header)
Deserialize and remove the header from the internal buffer.
uint32_t CopyData(uint8_t *buffer, uint32_t size) const
Copy the packet contents to a byte buffer.
Ptr< Packet > Copy(void) const
performs a COW copy of the packet.
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes.
A class representing a pcap file.
void Open(std::string const &filename, std::ios::openmode mode)
Create a new pcap file or open an existing pcap file.
void Read(uint8_t *const data, uint32_t maxBytes, uint32_t &tsSec, uint32_t &tsUsec, uint32_t &inclLen, uint32_t &origLen, uint32_t &readLen)
Read next packet from file.
void Write(uint32_t tsSec, uint32_t tsUsec, uint8_t const *const data, uint32_t totalLen)
Write next packet to file.
void Init(uint32_t dataLinkType, uint32_t snapLen=SNAPLEN_DEFAULT, int32_t timeZoneCorrection=ZONE_DEFAULT, bool swapMode=false, bool nanosecMode=false)
Initialize the pcap file associated with this object.
uint32_t GetDataLinkType(void)
Returns the data link type field of the pcap file as defined by the network field in the pcap global ...
void Close(void)
Close the underlying file.
void EnablePcapAll(std::string prefix, bool promiscuous=false)
Enable pcap output on each device (which is of the appropriate type) in the set of all nodes created ...
Build a set of PointToPointNetDevice objects.
void SetDeviceAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each NetDevice created by the helper.
void SetChannelAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each Channel created by the helper.
NetDeviceContainer Install(NodeContainer c)
Hold objects of type Ptr<T>.
virtual int Send(Ptr< Packet > p, uint32_t flags)=0
Send data (or dummy data) to the remote host.
void SetSendCallback(Callback< void, Ptr< Socket >, uint32_t > sendCb)
Notify application when space in transmit buffer is added.
virtual int Connect(const Address &address)=0
Initiate a connection to a remote host.
virtual int Close(void)=0
Close a socket.
virtual int Bind(const Address &address)=0
Allocate a local endpoint for this socket.
virtual uint32_t GetTxAvailable(void) const =0
Returns the number of bytes which can be sent in a single call to Send.
Hold variables of type string.
static TypeId GetTypeId(void)
Get the type ID.
bool IsStatusSuccess(void) const
Check if all tests passed.
std::string CreateDataDirFilename(std::string filename)
Construct the full path to a file in the data directory.
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
void SetDataDir(std::string directory)
Set the data directory where reference trace files can be found.
Simulation virtual time values and global simulation resolution.
int64_t GetMicroSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
double GetSeconds(void) const
Get an approximation of the time stored in this instance in the indicated unit.
AttributeValue implementation for Time.
a unique identifier for an interface.
AttributeValue implementation for TypeId.
Hold an unsigned integer type.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
void SetDefault(std::string name, const AttributeValue &value)
void Connect(std::string path, const CallbackBase &cb)
void ConnectWithoutContext(std::string path, const CallbackBase &cb)
#define NS_ABORT_MSG_UNLESS(cond, msg)
Abnormal program termination if a condition is false, with a message.
#define NS_FATAL_ERROR(msg)
Report a fatal error with a message and terminate.
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#define NS_LOG_DEBUG(msg)
Use NS_LOG to output a message of level LOG_DEBUG.
#define NS_LOG_INFO(msg)
Use NS_LOG to output a message of level LOG_INFO.
Time Now(void)
create an ns3::Time instance which contains the current simulation time.
#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.
@ LOG_LEVEL_ALL
Print everything.
@ LOG_PREFIX_FUNC
Prefix all trace prints with function.
@ LOG_LEVEL_DEBUG
LOG_DEBUG and above.
@ LOG_LEVEL_INFO
LOG_INFO and above.
void LogComponentEnable(char const *name, enum LogLevel level)
Enable the logging output associated with that log component.
void LogComponentEnableAll(enum LogLevel level)
Enable the logging output for all registered log components.
Callback< R, Ts... > MakeCallback(R(T::*memPtr)(Ts...), OBJ objPtr)
Build Callbacks for class method members which take varying numbers of arguments and potentially retu...
const uint32_t PCAP_LINK_TYPE
Some large random number – we use to verify data was written by this program.
const bool WRITE_VECTORS
Set to true to write response vectors.
const bool WRITE_PCAP
Set to true to write out pcap.
static Ns3TcpLossTestSuite g_ns3TcpLossTestSuite
Do not forget to allocate an instance of this TestSuite.
const bool WRITE_LOGGING
Set to true to write logging.
const uint32_t PCAP_SNAPLEN
Don't bother to save much data.
void WriteUntilBufferFull(Ptr< Socket >, uint32_t)
void StartFlow(Ptr< Socket >, Ipv4Address, uint16_t)
static void CwndTracer(uint32_t oldval, uint32_t newval)