23 #include "ns3/simulator.h"
26 #include "ns3/point-to-point-epc-helper.h"
27 #include "ns3/epc-enb-application.h"
28 #include "ns3/packet-sink-helper.h"
29 #include "ns3/udp-echo-helper.h"
30 #include "ns3/point-to-point-helper.h"
31 #include "ns3/csma-helper.h"
32 #include "ns3/internet-stack-helper.h"
33 #include "ns3/ipv4-address-helper.h"
34 #include "ns3/inet-socket-address.h"
35 #include "ns3/packet-sink.h"
36 #include <ns3/ipv4-static-routing-helper.h>
37 #include <ns3/ipv4-static-routing.h>
38 #include "ns3/boolean.h"
39 #include "ns3/uinteger.h"
40 #include "ns3/config.h"
41 #include "ns3/eps-bearer.h"
87 std::vector<UeDlTestData>
ues;
111 virtual void DoRun (
void);
138 remoteHostContainer.
Create (1);
141 internet.
Install (remoteHostContainer);
148 ipv4h.
SetBase (
"1.0.0.0",
"255.0.0.0");
149 ipv4h.
Assign (internetDevices);
156 remoteHostStaticRouting->AddNetworkRouteTo (
Ipv4Address (
"7.0.0.0"),
Ipv4Mask (
"255.255.255.0"), 1);
162 uint16_t cellIdCounter = 0;
163 uint64_t imsiCounter = 0;
165 for (std::vector<EnbDlTestData>::iterator enbit =
m_enbDlTestData.begin ();
176 uint16_t cellId = ++cellIdCounter;
179 ues.
Create (enbit->ues.size ());
192 std::vector<uint16_t> cellIds;
193 cellIds.push_back (cellId);
194 epcHelper->
AddEnb (enb, enbDevice, cellIds);
198 NS_ASSERT_MSG (enbApp != 0,
"cannot retrieve EpcEnbApplication");
201 rrc->SetS1SapProvider (enbApp->GetS1SapProvider ());
202 enbApp->SetS1SapUser (rrc->GetS1SapUser ());
209 for (uint32_t u = 0; u < ues.
GetN (); ++u)
221 uint16_t
port = 1234;
233 apps = client.
Install (remoteHost);
236 enbit->ues[u].clientApp = apps.
Get (0);
238 uint64_t imsi = ++imsiCounter;
239 epcHelper->
AddUe (ueLteDevice, imsi);
242 &EpcEnbS1SapProvider::InitialUeMessage,
243 enbApp->GetS1SapProvider (), imsi, (uint16_t) imsi);
250 for (std::vector<EnbDlTestData>::iterator enbit =
m_enbDlTestData.begin ();
254 for (std::vector<UeDlTestData>::iterator ueit = enbit->ues.begin ();
255 ueit < enbit->ues.end ();
258 NS_TEST_ASSERT_MSG_EQ (ueit->serverApp->GetTotalRx (), (ueit->numPkts) * (ueit->pktSize),
"wrong total received bytes");
262 Simulator::Destroy ();
282 std::vector<EnbDlTestData> v1;
285 e1.
ues.push_back (f1);
290 std::vector<EnbDlTestData> v2;
293 e2.
ues.push_back (f2_1);
295 e2.
ues.push_back (f2_2);
300 std::vector<EnbDlTestData> v3;
308 e3.
ues.push_back (f3_1);
310 e3.
ues.push_back (f3_2);
312 e3.
ues.push_back (f3_2);
313 std::vector<EnbDlTestData> v4;
319 std::vector<EnbDlTestData> v5;
322 e5.
ues.push_back (f5);
326 std::vector<EnbDlTestData> v6;
329 e6.
ues.push_back (f6);
333 std::vector<EnbDlTestData> v7;
336 e7.
ues.push_back (f7);
340 std::vector<EnbDlTestData> v8;
343 e8.
ues.push_back (f8);
std::vector< EnbDlTestData > m_enbDlTestData
ENB DL test data.
virtual ~EpcS1uDlTestCase()
virtual void DoRun(void)
Implementation to actually run this TestCase.
EpcS1uDlTestCase(std::string name, std::vector< EnbDlTestData > v)
Constructor.
Test that the S1-U interface implementation works correctly.
holds a vector of ns3::Application pointers.
Ptr< Application > Get(uint32_t i) const
Get the Ptr<Application> stored in this container at a given index.
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.
AttributeValue implementation for Boolean.
build a set of CsmaNetDevice objects
NetDeviceContainer Install(Ptr< Node > node) const
This method creates an ns3::CsmaChannel with the attributes configured by CsmaHelper::SetChannelAttri...
Class for representing data rates.
AttributeValue implementation for DataRate.
This application is installed inside eNBs and provides the bridge functionality for user data plane p...
This class contains the specification of EPS Bearers.
aggregate IP/TCP/UDP functionality to existing Nodes.
void Install(std::string nodeName) const
Aggregate implementations of the ns3::Ipv4, ns3::Ipv6, ns3::Udp, and ns3::Tcp classes onto the provid...
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
a class to represent an Ipv4 address mask
Helper class that adds ns3::Ipv4StaticRouting objects.
Ptr< Ipv4StaticRouting > GetStaticRouting(Ptr< Ipv4 > ipv4) const
Try and find the static routing protocol as either the main routing protocol or in the list of routin...
holds a vector of ns3::NetDevice pointers
uint32_t GetN(void) const
Get the number of Ptr<NetDevice> stored in this container.
Ptr< NetDevice > Get(uint32_t i) const
Get the Ptr<NetDevice> stored in this container at a given index.
virtual Ptr< Node > GetPgwNode() const
Get the PGW node.
virtual uint8_t ActivateEpsBearer(Ptr< NetDevice > ueLteDevice, uint64_t imsi, Ptr< EpcTft > tft, EpsBearer bearer)
Activate an EPS bearer, setting up the corresponding S1-U tunnel.
virtual void AddUe(Ptr< NetDevice > ueLteDevice, uint64_t imsi)
Notify the EPC of the existence of a new UE which might attach at a later time.
virtual Ipv4InterfaceContainer AssignUeIpv4Address(NetDeviceContainer ueDevices)
Assign IPv4 addresses to UE devices.
keep track of a set of node pointers.
uint32_t GetN(void) const
Get the number of Ptr<Node> stored in this container.
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.
Ptr< Application > GetApplication(uint32_t index) const
Retrieve the index-th Application associated to this node.
void SetAttribute(std::string name, const AttributeValue &value)
Set a single attribute, raising fatal errors if unsuccessful.
Ptr< T > GetObject(void) const
Get a pointer to the requested aggregated Object.
void AggregateObject(Ptr< Object > other)
Aggregate two Objects together.
A helper to make it easier to instantiate an ns3::PacketSinkApplication on a set of nodes.
ApplicationContainer Install(NodeContainer c) const
Install an ns3::PacketSinkApplication on each node of the input container configured with all the att...
Receive and consume traffic generated to an IP address and port.
virtual void AddEnb(Ptr< Node > enbNode, Ptr< NetDevice > lteEnbNetDevice, std::vector< uint16_t > cellIds)
Add an eNB to the EPC.
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.
NetDeviceContainer Install(NodeContainer c)
void AddTestCase(TestCase *testCase, TestDuration duration=QUICK)
Add an individual child TestCase to this test suite.
Simulation virtual time values and global simulation resolution.
AttributeValue implementation for Time.
Create an application which sends a UDP packet and waits for an echo of this packet.
void SetAttribute(std::string name, const AttributeValue &value)
Record an attribute to be set in each Application after it is is created.
ApplicationContainer Install(Ptr< Node > node) const
Create a udp echo client application on the specified node.
Hold an unsigned integer type.
EpcS1uDlTestSuite g_epcS1uDlTestSuiteInstance
#define NS_ASSERT_MSG(condition, message)
At runtime, in debugging builds, if this condition is not true, the program prints the message to out...
void SetDefault(std::string name, const AttributeValue &value)
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
#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.
Time Seconds(double value)
Construct a Time in the indicated unit.
Time MilliSeconds(uint64_t value)
Construct a Time in the indicated unit.
Every class exported by the ns3 library is enclosed in the ns3 namespace.
Custom structure for testing eNodeB downlink data, contains the list of data structures for UEs.
std::vector< UeDlTestData > ues
list of data structure for different UEs
Custom structure for testing UE downlink data.
uint32_t pktSize
packet size
UeDlTestData(uint32_t n, uint32_t s)
Constructor.
uint32_t numPkts
number of packets
Ptr< Application > clientApp
Client application.
Ptr< PacketSink > serverApp
Server application.
uint32_t pktSize
packet size used for the simulation (in bytes)