src/test/ns3tcp/ns3tcp-loss-test-suite.cc
author Josh Pelkey <jpelkey@gatech.edu>
Mon, 12 Apr 2010 20:50:04 -0400
changeset 6192 cf8ef89e65c4
parent 6191 5cde5bcbc902
child 6279 006a660a021a
permissions -rw-r--r--
Modifiy tcp loss test to help with bug 818
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     2
/*
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     3
 * Copyright (c) 2010 University of Washington
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     4
 *
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     8
 *
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    12
 * GNU General Public License for more details.
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    13
 *
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    17
 */
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    18
6192
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
    19
#include "receive-list-error-model.h"
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
    20
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    21
#include "ns3/log.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    22
#include "ns3/abort.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    23
#include "ns3/test.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    24
#include "ns3/pcap-file.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    25
#include "ns3/config.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    26
#include "ns3/string.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    27
#include "ns3/uinteger.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    28
#include "ns3/data-rate.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    29
#include "ns3/inet-socket-address.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    30
#include "ns3/point-to-point-helper.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    31
#include "ns3/internet-stack-helper.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    32
#include "ns3/ipv4-global-routing-helper.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    33
#include "ns3/ipv4-address-helper.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    34
#include "ns3/packet-sink-helper.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    35
#include "ns3/tcp-socket-factory.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    36
#include "ns3/node-container.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    37
#include "ns3/simulator.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    38
#include "ns3/error-model.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    39
#include "ns3/pointer.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    40
#include "ns3tcp-socket-writer.h"
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    41
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    42
using namespace ns3;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    43
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    44
NS_LOG_COMPONENT_DEFINE ("Ns3TcpLossTest");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    45
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    46
// ===========================================================================
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    47
// Tests of TCP implementation loss behavior
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    48
// ===========================================================================
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    49
//
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    50
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    51
class Ns3TcpLossTestCase1 : public TestCase
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    52
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    53
public:
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    54
  Ns3TcpLossTestCase1 ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    55
  virtual ~Ns3TcpLossTestCase1 () {}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    56
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    57
private:
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    58
  virtual bool DoRun (void);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    59
  bool m_writeResults;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    60
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    61
  void SinkRx (std::string path, Ptr<const Packet> p, const Address &address);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    62
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    63
  TestVectors<uint32_t> m_inputs;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    64
  TestVectors<uint32_t> m_responses;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    65
};
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    66
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    67
Ns3TcpLossTestCase1::Ns3TcpLossTestCase1 ()
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    68
  : TestCase ("Check that ns-3 TCP survives loss of first two SYNs"),
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    69
    m_writeResults (false)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    70
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    71
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    72
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    73
void 
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    74
Ns3TcpLossTestCase1::SinkRx (std::string path, Ptr<const Packet> p, const Address &address)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    75
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    76
  m_responses.Add (p->GetSize ());
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    77
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    78
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    79
bool
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    80
Ns3TcpLossTestCase1::DoRun (void)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    81
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    82
  uint16_t sinkPort = 50000;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    83
  double sinkStopTime = 40;  // sec; will trigger Socket::Close
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    84
  double writerStopTime = 30;  // sec; will trigger Socket::Close
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    85
  double simStopTime = 60;  // sec
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    86
  Time sinkStopTimeObj = Seconds (sinkStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    87
  Time writerStopTimeObj = Seconds (writerStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    88
  Time simStopTimeObj= Seconds (simStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    89
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    90
  Ptr<Node> n0 = CreateObject<Node> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    91
  Ptr<Node> n1 = CreateObject<Node> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    92
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    93
  PointToPointHelper pointToPoint;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    94
  pointToPoint.SetDeviceAttribute ("DataRate", StringValue ("5Mbps"));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    95
  pointToPoint.SetChannelAttribute ("Delay", StringValue ("200ms"));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    96
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    97
  NetDeviceContainer devices;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    98
  devices = pointToPoint.Install (n0, n1);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
    99
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   100
  InternetStackHelper internet;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   101
  internet.InstallAll ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   102
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   103
  Ipv4AddressHelper address;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   104
  address.SetBase ("10.1.1.0", "255.255.255.252");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   105
  Ipv4InterfaceContainer ifContainer = address.Assign (devices);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   106
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   107
  Ptr<SocketWriter> socketWriter = CreateObject<SocketWriter> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   108
  Address sinkAddress (InetSocketAddress (ifContainer.GetAddress (1), sinkPort));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   109
  socketWriter->Setup (n0, sinkAddress);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   110
  n0->AddApplication (socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   111
  socketWriter->SetStartTime (Seconds (0.));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   112
  socketWriter->SetStopTime (writerStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   113
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   114
  PacketSinkHelper sink ("ns3::TcpSocketFactory",
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   115
                         InetSocketAddress (Ipv4Address::GetAny (), sinkPort));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   116
  ApplicationContainer apps = sink.Install (n1);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   117
  // Start the sink application at time zero, and stop it at sinkStopTime
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   118
  apps.Start (Seconds (0.0));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   119
  apps.Stop (sinkStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   120
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   121
  Config::Connect ("/NodeList/*/ApplicationList/*/$ns3::PacketSink/Rx",
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   122
                   MakeCallback (&Ns3TcpLossTestCase1::SinkRx, this));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   123
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   124
  Simulator::Schedule(Seconds (2), &SocketWriter::Connect, socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   125
  Simulator::Schedule(Seconds (10), &SocketWriter::Write, socketWriter, 500);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   126
  m_inputs.Add (500);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   127
  Simulator::Schedule(writerStopTimeObj, &SocketWriter::Close, socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   128
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   129
  std::list<uint32_t> sampleList;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   130
  // Lose first two SYNs
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   131
  sampleList.push_back (0);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   132
  sampleList.push_back (1);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   133
  // This time, we'll explicitly create the error model we want
6192
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
   134
  Ptr<ReceiveListErrorModel> pem = CreateObject<ReceiveListErrorModel> ();
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   135
  pem->SetList (sampleList);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   136
  devices.Get (1)->SetAttribute ("ReceiveErrorModel", PointerValue (pem));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   137
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   138
  if (m_writeResults)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   139
    {
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   140
      pointToPoint.EnablePcapAll ("tcp-loss-test-case-1");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   141
      pointToPoint.EnableAsciiAll ("tcp-loss-test-case-1");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   142
    }
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   143
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   144
  Simulator::Stop (simStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   145
  Simulator::Run ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   146
  Simulator::Destroy ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   147
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   148
  // Compare inputs and outputs
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   149
  NS_TEST_ASSERT_MSG_EQ (m_inputs.GetN (), m_responses.GetN (), "Incorrect number of expected receive events");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   150
  for (uint32_t i = 0; i < m_responses.GetN (); i++)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   151
    {
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   152
      uint32_t in = m_inputs.Get (i);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   153
      uint32_t out = m_responses.Get (i);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   154
      NS_TEST_ASSERT_MSG_EQ (in, out, "Mismatch:  expected " << in << " bytes, got " << out << " bytes");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   155
    }
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   156
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   157
  return GetErrorStatus ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   158
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   159
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   160
class Ns3TcpLossTestCase2 : public TestCase
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   161
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   162
public:
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   163
  Ns3TcpLossTestCase2 ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   164
  virtual ~Ns3TcpLossTestCase2 () {}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   165
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   166
private:
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   167
  virtual bool DoRun (void);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   168
  bool m_writeResults;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   169
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   170
  void SinkRx (std::string path, Ptr<const Packet> p, const Address &address);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   171
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   172
  TestVectors<uint32_t> m_inputs;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   173
  TestVectors<uint32_t> m_responses;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   174
};
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   175
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   176
Ns3TcpLossTestCase2::Ns3TcpLossTestCase2 ()
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   177
  : TestCase ("Check that ns-3 TCP survives loss of first data packet"),
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   178
    m_writeResults (false)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   179
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   180
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   181
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   182
void 
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   183
Ns3TcpLossTestCase2::SinkRx (std::string path, Ptr<const Packet> p, const Address &address)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   184
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   185
  m_responses.Add (p->GetSize ());
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   186
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   187
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   188
bool
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   189
Ns3TcpLossTestCase2::DoRun (void)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   190
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   191
  uint16_t sinkPort = 50000;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   192
  double sinkStopTime = 40;  // sec; will trigger Socket::Close
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   193
  double writerStopTime = 12;  // sec; will trigger Socket::Close
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   194
  double simStopTime = 60;  // sec
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   195
  Time sinkStopTimeObj = Seconds (sinkStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   196
  Time writerStopTimeObj = Seconds (writerStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   197
  Time simStopTimeObj= Seconds (simStopTime);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   198
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   199
  Ptr<Node> n0 = CreateObject<Node> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   200
  Ptr<Node> n1 = CreateObject<Node> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   201
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   202
  PointToPointHelper pointToPoint;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   203
  pointToPoint.SetDeviceAttribute ("DataRate", StringValue ("5Mbps"));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   204
  pointToPoint.SetChannelAttribute ("Delay", StringValue ("200ms"));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   205
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   206
  NetDeviceContainer devices;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   207
  devices = pointToPoint.Install (n0, n1);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   208
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   209
  InternetStackHelper internet;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   210
  internet.InstallAll ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   211
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   212
  Ipv4AddressHelper address;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   213
  address.SetBase ("10.1.1.0", "255.255.255.252");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   214
  Ipv4InterfaceContainer ifContainer = address.Assign (devices);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   215
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   216
  Ptr<SocketWriter> socketWriter = CreateObject<SocketWriter> ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   217
  Address sinkAddress (InetSocketAddress (ifContainer.GetAddress (1), sinkPort));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   218
  socketWriter->Setup (n0, sinkAddress);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   219
  n0->AddApplication (socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   220
  socketWriter->SetStartTime (Seconds (0.));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   221
  socketWriter->SetStopTime (writerStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   222
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   223
  PacketSinkHelper sink ("ns3::TcpSocketFactory",
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   224
                         InetSocketAddress (Ipv4Address::GetAny (), sinkPort));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   225
  ApplicationContainer apps = sink.Install (n1);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   226
  // Start the sink application at time zero, and stop it at sinkStopTime
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   227
  apps.Start (Seconds (0.0));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   228
  apps.Stop (sinkStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   229
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   230
  Config::Connect ("/NodeList/*/ApplicationList/*/$ns3::PacketSink/Rx",
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   231
                   MakeCallback (&Ns3TcpLossTestCase2::SinkRx, this));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   232
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   233
  Simulator::Schedule(Seconds (2), &SocketWriter::Connect, socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   234
  Simulator::Schedule(Seconds (10), &SocketWriter::Write, socketWriter, 500);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   235
  m_inputs.Add (500);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   236
  Simulator::Schedule(writerStopTimeObj, &SocketWriter::Close, socketWriter);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   237
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   238
  std::list<uint32_t> sampleList;
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   239
  // Lose first data segment
6192
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
   240
  sampleList.push_back (2);
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   241
  // This time, we'll explicitly create the error model we want
6192
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
   242
  Ptr<ReceiveListErrorModel> pem = CreateObject<ReceiveListErrorModel> ();
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   243
  pem->SetList (sampleList);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   244
  devices.Get (1)->SetAttribute ("ReceiveErrorModel", PointerValue (pem));
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   245
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   246
  if (m_writeResults)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   247
    {
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   248
      pointToPoint.EnablePcapAll ("tcp-loss-test-case-2");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   249
      pointToPoint.EnableAsciiAll ("tcp-loss-test-case-2");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   250
    }
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   251
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   252
  Simulator::Stop (simStopTimeObj);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   253
  Simulator::Run ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   254
  Simulator::Destroy ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   255
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   256
  // Compare inputs and outputs
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   257
  NS_TEST_ASSERT_MSG_EQ (m_inputs.GetN (), m_responses.GetN (), "Incorrect number of expected receive events");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   258
  for (uint32_t i = 0; i < m_responses.GetN (); i++)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   259
    {
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   260
      uint32_t in = m_inputs.Get (i);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   261
      uint32_t out = m_responses.Get (i);
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   262
      NS_TEST_ASSERT_MSG_EQ (in, out, "Mismatch:  expected " << in << " bytes, got " << out << " bytes");
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   263
    }
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   264
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   265
  return GetErrorStatus ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   266
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   267
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   268
class Ns3TcpLossTestSuite : public TestSuite
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   269
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   270
public:
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   271
  Ns3TcpLossTestSuite ();
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   272
};
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   273
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   274
Ns3TcpLossTestSuite::Ns3TcpLossTestSuite ()
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   275
  : TestSuite ("ns3-tcp-loss", SYSTEM)
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   276
{
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   277
  AddTestCase (new Ns3TcpLossTestCase1);
6192
cf8ef89e65c4 Modifiy tcp loss test to help with bug 818
Josh Pelkey <jpelkey@gatech.edu>
parents: 6191
diff changeset
   278
  AddTestCase (new Ns3TcpLossTestCase2);
6191
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   279
}
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   280
5cde5bcbc902 Add loss-based tcp test suite
Tom Henderson <tomh@tomh.org>
parents:
diff changeset
   281
Ns3TcpLossTestSuite ns3TcpLossTestSuite;