A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
LteUeMeasurementsPiecewiseTestCase2 Class Reference

Testing UE measurements in LTE with simulation of 2 eNodeB and 1 UE in piecewise configuration and 240 ms report interval. More...

#include "lte-test-ue-measurements.h"

+ Inheritance diagram for LteUeMeasurementsPiecewiseTestCase2:
+ Collaboration diagram for LteUeMeasurementsPiecewiseTestCase2:

Public Member Functions

 LteUeMeasurementsPiecewiseTestCase2 (std::string name, LteRrcSap::ReportConfigEutra config, std::vector< Time > expectedTime, std::vector< uint8_t > expectedRsrp)
 Constructor.
 
 ~LteUeMeasurementsPiecewiseTestCase2 () override
 
void RecvMeasurementReportCallback (std::string context, uint64_t imsi, uint16_t cellId, uint16_t rnti, LteRrcSap::MeasurementReport report)
 Triggers when eNodeB receives measurement report from UE, then perform verification on it.
 
- Public Member Functions inherited from ns3::TestCase
 TestCase (const TestCase &)=delete
 
virtual ~TestCase ()
 Destructor.
 
std::string GetName () const
 
TestCaseoperator= (const TestCase &)=delete
 

Private Member Functions

void DoRun () override
 Setup the simulation with the intended UE measurement reporting configuration, run it, and connect the RecvMeasurementReportCallback function to the LteUeRrc::RecvMeasurementReport trace source.
 
void DoTeardown () override
 Runs at the end of the simulation, verifying that all expected measurement reports have been examined.
 
void TeleportFar ()
 Teleport far function.
 
void TeleportNear ()
 Teleport near function.
 
void TeleportVeryFar ()
 Teleport very far function.
 
void TeleportVeryNear ()
 Teleport very near function.
 

Private Attributes

LteRrcSap::ReportConfigEutra m_config
 The active report triggering configuration.
 
uint8_t m_expectedMeasId
 The measurement identity being tested.
 
std::vector< uint8_t > m_expectedRsrp
 The list of expected values of RSRP (in 3GPP range unit) from the measurement reports received.
 
std::vector< Timem_expectedTime
 The list of expected time when measurement reports are received by eNodeB.
 
std::vector< uint8_t >::iterator m_itExpectedRsrp
 Pointer to the element of m_expectedRsrp which is expected to occur next in the simulation.
 
std::vector< Time >::iterator m_itExpectedTime
 Pointer to the element of m_expectedTime which is expected to occur next in the simulation.
 
Ptr< MobilityModelm_ueMobility
 the mobility model
 

Additional Inherited Members

- Public Types inherited from ns3::TestCase
enum class  Duration { QUICK = 1 , EXTENSIVE = 2 , TAKES_FOREVER = 3 }
 How long the test takes to execute. More...
 
- Static Public Attributes inherited from ns3::TestCase
static constexpr auto QUICK = Duration::QUICK
 Deprecated test duration simple enums.
 
static constexpr auto EXTENSIVE = Duration::EXTENSIVE
 
static constexpr auto TAKES_FOREVER = Duration::TAKES_FOREVER
 
- Protected Member Functions inherited from ns3::TestCase
 TestCase (std::string name)
 Constructor.
 
void AddTestCase (TestCase *testCase, Duration duration=Duration::QUICK)
 Add an individual child TestCase to this test suite.
 
TestCaseGetParent () const
 Get the parent of this TestCase.
 
bool IsStatusFailure () const
 Check if any tests failed.
 
bool IsStatusSuccess () const
 Check if all tests passed.
 
void SetDataDir (std::string directory)
 Set the data directory where reference trace files can be found.
 
void ReportTestFailure (std::string cond, std::string actual, std::string limit, std::string message, std::string file, int32_t line)
 Log the failure of this TestCase.
 
bool MustAssertOnFailure () const
 Check if this run should assert on failure.
 
bool MustContinueOnFailure () const
 Check if this run should continue on failure.
 
std::string CreateDataDirFilename (std::string filename)
 Construct the full path to a file in the data directory.
 
std::string CreateTempDirFilename (std::string filename)
 Construct the full path to a file in a temporary directory.
 

Detailed Description

Testing UE measurements in LTE with simulation of 2 eNodeB and 1 UE in piecewise configuration and 240 ms report interval.

Here is intenisvely test events A1 and A2. A1 event should be triggered when the serving cell becomes better than a given threshold. A2 shall be triggered when the serving cell becomes worse than threshold. A3 event is triggered when the neighbour becomes offset better than the PCell. In this test UE is being transported several times during the simulation duration. Then the test checks if measurement report contains correct RSRP and RSRQ result, than if CQI info is correctly generated, if the reporting occurs at the correct time stamp in the simulation and according to the measurements configuration. It also checks if the reported values of RSRP and RSRQ are equal to expected reference values.

Definition at line 280 of file lte-test-ue-measurements.h.

Constructor & Destructor Documentation

◆ LteUeMeasurementsPiecewiseTestCase2()

LteUeMeasurementsPiecewiseTestCase2::LteUeMeasurementsPiecewiseTestCase2 ( std::string name,
LteRrcSap::ReportConfigEutra config,
std::vector< Time > expectedTime,
std::vector< uint8_t > expectedRsrp )

Constructor.

Parameters
namethe reference name
configLteRrcSap::ReportConfigEutra
expectedTimethe expected time
expectedRsrpthe expected RSRP

Definition at line 1402 of file lte-test-ue-measurements.cc.

References m_expectedRsrp, m_expectedTime, m_itExpectedRsrp, m_itExpectedTime, NS_FATAL_ERROR, and NS_LOG_INFO.

◆ ~LteUeMeasurementsPiecewiseTestCase2()

LteUeMeasurementsPiecewiseTestCase2::~LteUeMeasurementsPiecewiseTestCase2 ( )
override

Definition at line 1426 of file lte-test-ue-measurements.cc.

References NS_LOG_FUNCTION.

Member Function Documentation

◆ DoRun()

void LteUeMeasurementsPiecewiseTestCase2::DoRun ( )
overrideprivatevirtual

Setup the simulation with the intended UE measurement reporting configuration, run it, and connect the RecvMeasurementReportCallback function to the LteUeRrc::RecvMeasurementReport trace source.

Implements ns3::TestCase.

Definition at line 1432 of file lte-test-ue-measurements.cc.

References ns3::Config::Connect(), ns3::NodeContainer::Create(), ns3::CreateObject(), ns3::Simulator::Destroy(), ns3::EpsBearer::GBR_CONV_VOICE, ns3::NetDeviceContainer::Get(), ns3::NodeContainer::Get(), ns3::TestCase::GetName(), ns3::Object::GetObject(), m_config, m_expectedMeasId, m_ueMobility, ns3::MakeCallback(), ns3::MilliSeconds(), NS_LOG_INFO, ns3::FfMacScheduler::PUSCH_UL_CQI, RecvMeasurementReportCallback(), ns3::Simulator::Run(), ns3::Simulator::Schedule(), ns3::Seconds(), ns3::Config::SetDefault(), ns3::Simulator::Stop(), TeleportFar(), TeleportNear(), TeleportVeryFar(), and TeleportVeryNear().

+ Here is the call graph for this function:

◆ DoTeardown()

void LteUeMeasurementsPiecewiseTestCase2::DoTeardown ( )
overrideprivatevirtual

Runs at the end of the simulation, verifying that all expected measurement reports have been examined.

Reimplemented from ns3::TestCase.

Definition at line 1551 of file lte-test-ue-measurements.cc.

References m_expectedRsrp, m_expectedTime, m_itExpectedRsrp, m_itExpectedTime, NS_ASSERT, NS_LOG_FUNCTION, NS_TEST_ASSERT_MSG_EQ, and ns3::Time::S.

◆ RecvMeasurementReportCallback()

void LteUeMeasurementsPiecewiseTestCase2::RecvMeasurementReportCallback ( std::string context,
uint64_t imsi,
uint16_t cellId,
uint16_t rnti,
LteRrcSap::MeasurementReport report )

Triggers when eNodeB receives measurement report from UE, then perform verification on it.

The trigger is set up beforehand by connecting to the LteUeRrc::RecvMeasurementReport trace source.

Verification consists of checking whether the report carries the right value of RSRP or not, and whether it occurs at the expected time or not.

Parameters
contextthe context
imsithe IMSI
cellIdthe cell ID
rntithe RNTI
reportLteRrcSap::MeasurementReport

Definition at line 1563 of file lte-test-ue-measurements.cc.

References ns3::Time::GetMilliSeconds(), ns3::LteRrcSap::MeasResults::haveMeasResultNeighCells, m_expectedMeasId, m_expectedRsrp, m_expectedTime, m_itExpectedRsrp, m_itExpectedTime, ns3::LteRrcSap::MeasResults::measId, ns3::LteRrcSap::MeasResults::measResultListEutra, ns3::LteRrcSap::MeasResults::measResultPCell, ns3::LteRrcSap::MeasurementReport::measResults, ns3::Simulator::Now(), NS_ASSERT, NS_LOG_DEBUG, NS_LOG_FUNCTION, NS_TEST_ASSERT_MSG_EQ, ns3::EutranMeasurementMapping::RsrpRange2Dbm(), ns3::LteRrcSap::MeasResultPCell::rsrpResult, ns3::EutranMeasurementMapping::RsrqRange2Db(), ns3::LteRrcSap::MeasResultPCell::rsrqResult, and ns3::Time::S.

Referenced by DoRun().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ TeleportFar()

void LteUeMeasurementsPiecewiseTestCase2::TeleportFar ( )
private

Teleport far function.

Definition at line 1667 of file lte-test-ue-measurements.cc.

References m_ueMobility, and NS_LOG_FUNCTION.

Referenced by DoRun().

+ Here is the caller graph for this function:

◆ TeleportNear()

void LteUeMeasurementsPiecewiseTestCase2::TeleportNear ( )
private

Teleport near function.

Definition at line 1660 of file lte-test-ue-measurements.cc.

References m_ueMobility, and NS_LOG_FUNCTION.

Referenced by DoRun().

+ Here is the caller graph for this function:

◆ TeleportVeryFar()

void LteUeMeasurementsPiecewiseTestCase2::TeleportVeryFar ( )
private

Teleport very far function.

Definition at line 1674 of file lte-test-ue-measurements.cc.

References m_ueMobility, and NS_LOG_FUNCTION.

Referenced by DoRun().

+ Here is the caller graph for this function:

◆ TeleportVeryNear()

void LteUeMeasurementsPiecewiseTestCase2::TeleportVeryNear ( )
private

Teleport very near function.

Definition at line 1653 of file lte-test-ue-measurements.cc.

References m_ueMobility, and NS_LOG_FUNCTION.

Referenced by DoRun().

+ Here is the caller graph for this function:

Member Data Documentation

◆ m_config

LteRrcSap::ReportConfigEutra LteUeMeasurementsPiecewiseTestCase2::m_config
private

The active report triggering configuration.

Definition at line 347 of file lte-test-ue-measurements.h.

Referenced by DoRun().

◆ m_expectedMeasId

uint8_t LteUeMeasurementsPiecewiseTestCase2::m_expectedMeasId
private

The measurement identity being tested.

Measurement reports with different measurement identity (e.g. from handover algorithm) will be ignored.

Definition at line 378 of file lte-test-ue-measurements.h.

Referenced by DoRun(), and RecvMeasurementReportCallback().

◆ m_expectedRsrp

std::vector<uint8_t> LteUeMeasurementsPiecewiseTestCase2::m_expectedRsrp
private

The list of expected values of RSRP (in 3GPP range unit) from the measurement reports received.

Definition at line 359 of file lte-test-ue-measurements.h.

Referenced by LteUeMeasurementsPiecewiseTestCase2(), DoTeardown(), and RecvMeasurementReportCallback().

◆ m_expectedTime

std::vector<Time> LteUeMeasurementsPiecewiseTestCase2::m_expectedTime
private

The list of expected time when measurement reports are received by eNodeB.

Definition at line 353 of file lte-test-ue-measurements.h.

Referenced by LteUeMeasurementsPiecewiseTestCase2(), DoTeardown(), and RecvMeasurementReportCallback().

◆ m_itExpectedRsrp

std::vector<uint8_t>::iterator LteUeMeasurementsPiecewiseTestCase2::m_itExpectedRsrp
private

Pointer to the element of m_expectedRsrp which is expected to occur next in the simulation.

Definition at line 371 of file lte-test-ue-measurements.h.

Referenced by LteUeMeasurementsPiecewiseTestCase2(), DoTeardown(), and RecvMeasurementReportCallback().

◆ m_itExpectedTime

std::vector<Time>::iterator LteUeMeasurementsPiecewiseTestCase2::m_itExpectedTime
private

Pointer to the element of m_expectedTime which is expected to occur next in the simulation.

Definition at line 365 of file lte-test-ue-measurements.h.

Referenced by LteUeMeasurementsPiecewiseTestCase2(), DoTeardown(), and RecvMeasurementReportCallback().

◆ m_ueMobility

Ptr<MobilityModel> LteUeMeasurementsPiecewiseTestCase2::m_ueMobility
private

the mobility model

Definition at line 380 of file lte-test-ue-measurements.h.

Referenced by DoRun(), TeleportFar(), TeleportNear(), TeleportVeryFar(), and TeleportVeryNear().


The documentation for this class was generated from the following files: