#include <iostream>#include <fstream>#include <sstream>#include <string>#include <vector>#include <list>#include <limits>#include <stdint.h>#include "system-wall-clock-ms.h"#include "deprecated.h" Include dependency graph for test.h:
 Include dependency graph for test.h: This graph shows which files directly or indirectly include this file:
 This graph shows which files directly or indirectly include this file:Go to the source code of this file.
| Classes | |
| class | ns3::TestCase | 
| encapsulates test code  More... | |
| class | ns3::TestRunner | 
| A runner to execute tests.  More... | |
| class | ns3::TestSuite | 
| A suite of tests to run.  More... | |
| class | ns3::TestVectors< T > | 
| A simple way to store test vectors (for stimulus or from responses)  More... | |
| Namespaces | |
| ns3 | |
| Every class exported by the ns3 library is enclosed in the ns3 namespace. | |
| Macros | |
| #define | ASSERT_ON_FAILURE | 
| #define | CONTINUE_ON_FAILURE | 
| #define | CONTINUE_ON_FAILURE_RETURNS_BOOL | 
| #define | NS_TEST_ASSERT_MSG_EQ(actual, limit, msg) NS_TEST_ASSERT_MSG_EQ_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are equal and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_EQ_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL(actual, limit, msg) NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are equal and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_EQ_TOL(actual, limit, tol, msg) NS_TEST_ASSERT_MSG_EQ_TOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
| Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_EQ_TOL_INTERNAL(actual, limit, tol, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL(actual, limit, tol, msg) NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
| Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL_INTERNAL(actual, limit, tol, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_GT(actual, limit, msg) NS_TEST_ASSERT_MSG_GT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual value is greater than a limit and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_GT_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_LT(actual, limit, msg) NS_TEST_ASSERT_MSG_LT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual value is less than a limit and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_LT_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_NE(actual, limit, msg) NS_TEST_ASSERT_MSG_NE_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are not equal and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_NE_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL(actual, limit, msg) NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are not equal and report and abort if not.  More... | |
| #define | NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_EXPECT_MSG_EQ(actual, limit, msg) NS_TEST_EXPECT_MSG_EQ_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are equal and report if not.  More... | |
| #define | NS_TEST_EXPECT_MSG_EQ_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_EXPECT_MSG_EQ_TOL(actual, limit, tol, msg) NS_TEST_EXPECT_MSG_EQ_TOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
| Test that actual and expected (limit) values are equal to plus or minus some tolerance and report if not.  More... | |
| #define | NS_TEST_EXPECT_MSG_EQ_TOL_INTERNAL(actual, limit, tol, msg, file, line) | 
| #define | NS_TEST_EXPECT_MSG_GT(actual, limit, msg) NS_TEST_EXPECT_MSG_GT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual value is greater than a limit and report if not.  More... | |
| #define | NS_TEST_EXPECT_MSG_GT_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_EXPECT_MSG_LT(actual, limit, msg) NS_TEST_EXPECT_MSG_LT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual value is less than a limit and report if not.  More... | |
| #define | NS_TEST_EXPECT_MSG_LT_INTERNAL(actual, limit, msg, file, line) | 
| #define | NS_TEST_EXPECT_MSG_NE(actual, limit, msg) NS_TEST_EXPECT_MSG_NE_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
| Test that an actual and expected (limit) value are not equal and report if not.  More... | |
| #define | NS_TEST_EXPECT_MSG_NE_INTERNAL(actual, limit, msg, file, line) | 
| Functions | |
| bool | ns3::TestDoubleIsEqual (const double a, const double b, const double epsilon=std::numeric_limits< double >::epsilon()) | 
| Compare two double precision floating point numbers and declare them equal if they are within some epsilon of each other.  More... | |
| #define ASSERT_ON_FAILURE | 
| #define CONTINUE_ON_FAILURE | 
| #define CONTINUE_ON_FAILURE_RETURNS_BOOL | 
| #define NS_TEST_ASSERT_MSG_EQ | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_EQ_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are equal and report and abort if not.
Check to see if the expected (limit) value is equal to the actual value found in a test case. If the two values are equal nothing happens, but if the comparison fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 122 of file test.h.
Referenced by ns3::RrcHeaderTestCase::AssertEqualRadioResourceConfigDedicated(), ns3::LteRrcConnectionEstablishmentTestCase::CheckConnected(), ns3::LteX2HandoverTestCase::CheckConnected(), PeerManagementProtocolRegressionTest::CreateDevices(), ns3::aodv::Bug772ChainTest::CreateDevices(), HwmpProactiveRegressionTest::CreateDevices(), FlameRegressionTest::CreateDevices(), HwmpDoRfRegressionTest::CreateDevices(), HwmpSimplestRegressionTest::CreateDevices(), ns3::aodv::ChainRegressionTest::CreateDevices(), ns3::olsr::Bug780Test::CreateNodes(), ns3::olsr::HelloRegressionTest::CreateNodes(), ns3::LteLinkAdaptationTestCase::DlScheduling(), ns3::LteInterferenceTestCase::DlScheduling(), ns3::LtePathlossModelSystemTestCase::DlScheduling(), ns3::LteRlcAmTransmitterTestCase::DoCheckDataReceived(), ns3::LteRlcUmTransmitterTestCase::DoCheckDataReceived(), BufferTest::DoRun(), SampleTestCase1::DoRun(), CognitiveTestCase1::DoRun(), WatchdogTestCase::DoRun(), Ipv6AddressTestCase1::DoRun(), ns3::OlsrEmfTestCase::DoRun(), BasicTracedCallbackTestCase::DoRun(), TypeTraitsTestCase::DoRun(), TimeSimpleTestCase::DoRun(), ns3::GlobalValueTestCase::DoRun(), ns3::flame::FlameHeaderTest::DoRun(), IpAddressHelperTestCasev6::DoRun(), ns3::dot11s::MeshHeaderTest::DoRun(), ns3::aodv::LoopbackTestCase::DoRun(), BasicCallbackTestCase::DoRun(), ns3::BriteTopologyStructureTestCase::DoRun(), ns3::MeshInformationElementVectorBist::DoRun(), SwitchFlowTableTestCase::DoRun(), ns3::LteRlcAmE2eTestCase::DoRun(), ns3::LteRlcUmE2eTestCase::DoRun(), ns3::EpsGtpuHeaderTestCase::DoRun(), ns3::AnimationInterfaceTestCase::DoRun(), StaticRoutingSlash32TestCase::DoRun(), UdpClientServerTestCase::DoRun(), ns3::Ipv4L3ProtocolTestCase::DoRun(), BasicEnergyUpdateTest::DoRun(), ns3::OlsrMidTestCase::DoRun(), DsaRequestTestCase::DoRun(), Ns3TcpNoDelayTestCase::DoRun(), ns3::Ipv6L3ProtocolTestCase::DoRun(), Ns3TcpSocketTestCase1::DoRun(), Ns3WimaxCsParamTlvTestCase::DoRun(), TimerStateTestCase::DoRun(), ns3::DsdvHeaderTestCase::DoRun(), DynamicGlobalRoutingTestCase::DoRun(), NscTcpLossTestCase1::DoRun(), Ipv4ListRoutingNegativeTestCase::DoRun(), WifiInterferenceTestCase::DoRun(), CsmaBridgeTestCase::DoRun(), BatteryLifetimeTest::DoRun(), Ipv6ListRoutingNegativeTestCase::DoRun(), ns3::RandomRoomPositionAllocatorTestCase::DoRun(), ns3::EpcTftClassifierTestCase::DoRun(), BasicAddTestCase::DoRun(), ErrorModelSimple::DoRun(), RandomVariableStreamUniformTestCase::DoRun(), ns3::SpectrumIdealPhyTestCase::DoRun(), CommandLineBooleanTestCase::DoRun(), ns3::LteNoisePsdTestCase::DoRun(), ns3::EpcS1uDlTestCase::DoRun(), Ipv4ListRoutingPositiveTestCase::DoRun(), WriteModeCreateTestCase::DoRun(), Ipv6ListRoutingPositiveTestCase::DoRun(), ns3::LteEpcE2eDataTestCase::DoRun(), ns3::BuildingsHelperOneTestCase::DoRun(), RandomNumberSerializationTestCase::DoRun(), ns3::DsdvTableTestCase::DoRun(), ns3::CreateObjectTestCase::DoRun(), CommandLineIntTestCase::DoRun(), ns3::LteTxPsdTestCase::DoRun(), UdpTraceClientServerTestCase::DoRun(), StringContextAddTestCase::DoRun(), Ns3WimaxSfTlvTestCase::DoRun(), CommandLineUnsignedIntTestCase::DoRun(), ns3::SameRoomPositionAllocatorTestCase::DoRun(), RootNamespaceConfigTestCase::DoRun(), BurstErrorModelSimple::DoRun(), ns3::OlsrHelloTestCase::DoRun(), Ns3TcpSocketTestCase2::DoRun(), NscTcpLossTestCase2::DoRun(), CsmaBroadcastTestCase::DoRun(), MakeCallbackTestCase::DoRun(), ns3::AggregateObjectTestCase::DoRun(), Int64x64Bug455TestCase::DoRun(), Ns3TcpCwndTestCase1::DoRun(), RandomVariableStreamUniformAntitheticTestCase::DoRun(), CommandLineStringTestCase::DoRun(), IpAddressHelperTestCasev4::DoRun(), PacketLossCounterTestCase::DoRun(), ns3::AcousticModemEnergyDepletionTestCase::DoRun(), FullyQualifiedAddTestCase::DoRun(), ReadModeCreateTestCase::DoRun(), Int64x64Bug863TestCase::DoRun(), UnderRootNamespaceConfigTestCase::DoRun(), BasicEnergyDepletionTest::DoRun(), ns3::OlsrTcTestCase::DoRun(), ns3::Ns2MobilityHelperTest::DoRun(), Int64x64CompareTestCase::DoRun(), ns3::RrcConnectionRequestTestCase::DoRun(), ns3::OlsrHnaTestCase::DoRun(), RelativeAddTestCase::DoRun(), ns3::EpcS1uUlTestCase::DoRun(), CsmaMulticastTestCase::DoRun(), GlobalRoutingSlash32TestCase::DoRun(), ns3::RrcConnectionSetupTestCase::DoRun(), MakeBoundCallbackTestCase::DoRun(), AttributeTestCase< T >::DoRun(), ObjectVectorConfigTestCase::DoRun(), ns3::Bug555TestCase::DoRun(), BasicRenameTestCase::DoRun(), ns3::RrcConnectionSetupCompleteTestCase::DoRun(), ns3::ObjectFactoryTestCase::DoRun(), MatrixPropagationLossModelTestCase::DoRun(), Ns3TcpCwndTestCase2::DoRun(), ns3::RrcConnectionReconfigurationCompleteTestCase::DoRun(), StringContextRenameTestCase::DoRun(), NullifyCallbackTestCase::DoRun(), FileHeaderTestCase::DoRun(), ns3::RrcConnectionReconfigurationTestCase::DoRun(), CsmaOneSubnetTestCase::DoRun(), FullyQualifiedRenameTestCase::DoRun(), ObjectVectorTraceConfigTestCase::DoRun(), RelativeRenameTestCase::DoRun(), FindPathTestCase::DoRun(), CsmaPacketSocketTestCase::DoRun(), ns3::HandoverPreparationInfoTestCase::DoRun(), BasicFindTestCase::DoRun(), RecordHeaderTestCase::DoRun(), ns3::RrcConnectionReestablishmentRequestTestCase::DoRun(), RandomVariableStreamAttributeTestCase::DoRun(), CsmaPingTestCase::DoRun(), StringContextFindTestCase::DoRun(), ns3::RrcConnectionReestablishmentTestCase::DoRun(), ObjectVectorAttributeTestCase::DoRun(), FullyQualifiedFindTestCase::DoRun(), ns3::RrcConnectionReestablishmentCompleteTestCase::DoRun(), ObjectMapAttributeTestCase::DoRun(), CsmaRawIpSocketTestCase::DoRun(), ns3::RrcConnectionRejectTestCase::DoRun(), RelativeFindTestCase::DoRun(), IntegerTraceSourceAttributeTestCase::DoRun(), ns3::MeasurementReportTestCase::DoRun(), AlternateFindTestCase::DoRun(), CsmaStarTestCase::DoRun(), IntegerTraceSourceTestCase::DoRun(), ReadFileTestCase::DoRun(), TracedCallbackTestCase::DoRun(), DiffTestCase::DoRun(), PointerAttributeTestCase::DoRun(), CallbackValueTestCase::DoRun(), ns3::SpectrumInterferenceTestCase::RetrieveTestResult(), Ipv6PacketInfoTagTest::RxCb(), Ipv4PacketInfoTagTest::RxCb(), PbbTestCase::TestDeserialize(), PbbTestCase::TestSerialize(), ns3::LteInterferenceTestCase::UlScheduling(), and Ns3TcpCwndTestCase2::VerifyCwndRun().
| #define NS_TEST_ASSERT_MSG_EQ_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Definition at line 77 of file test.h.
Referenced by PacketMetadataTest::CheckHistory(), and BufferTest::EnsureWrittenBytes().
| #define NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are equal and report and abort if not.
Check to see if the expected (limit) value is equal to the actual value found in a test case. If the two values are equal nothing happens, but if the comparison fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| msg | Message that is output if the test does not pass. | 
This function returns a boolean value.
Definition at line 176 of file test.h.
Referenced by BatteryLifetimeTest::ConstantLoadTest(), BasicEnergyDepletionTest::DepletionTestCase(), UanTest::DoPhyTests(), BasicEnergyUpdateTest::StateSwitchTest(), and ns3::Ns2MobilityHelperTest::WriteTrace().
| #define NS_TEST_ASSERT_MSG_EQ_RETURNS_BOOL_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_EQ_TOL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_EQ_TOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and abort if not.
Check to see if the expected (limit) value is equal to the actual value found in a test case to some tolerance. This is not the same thing as asking if two floating point are equal to within some epsilon, but is useful for that case. This assertion is geared toward more of a measurement problem. Consider measuring a physical rod of some kind that you have ordered. You need to determine if it is "good." You won't measure the rod to an arbitrary precision of sixteen significant figures, you will measure the rod to determine if its length is within the tolerances you provided. For example, 12.00 inches plus or minus .005 inch may be just fine.
In ns-3, you might want to measure a signal to noise ratio and check to see if the answer is what you expect. If you naively measure (double)1128.93 and compare this number with a constant 1128.93 you are almost certainly going to have your test fail because of floating point rounding errors. We provide a floating point comparison function ns3::TestDoubleIsEqual() but you will probably quickly find that is not what you want either. It may turn out to be the case that when you measured an snr that printed as 1128.93, what was actually measured was something more like 1128.9287653857625442 for example. Given that the double epsilon is on the order of 0.0000000000000009, you would need to provide sixteen significant figures of expected value for this kind of test to pass even with a typical test for floating point "approximate equality." That is clearly not required or desired. You really want to be able to provide 1128.93 along with a tolerance just like you provided 12 inches +- 0.005 inch above.
This assertion is designed for real measurements by taking into account measurement tolerances. By doing so it also automatically compensates for floating point rounding errors. If you really want to check floating point equality down to the numeric_limits<double>::epsilon () range, consider using ns3::TestDoubleIsEqual().
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| tol | Tolerance of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 311 of file test.h.
Referenced by SampleTestCase1::DoRun(), CognitiveTestCase1::DoRun(), TimeSimpleTestCase::DoRun(), RttTestCase::DoRun(), ns3::LiIonEnergyTestCase::DoRun(), ns3::LenaMimoTestCase::DoRun(), OneIntegerTestCase::DoRun(), OneIntegerAverageTestCase::DoRun(), UanTest::DoRun(), ns3::LteEarfcnTestCase::DoRun(), ns3::ItuR1411LosPropagationLossModelTestCase::DoRun(), ns3::ItuR1411NlosOverRooftopPropagationLossModelTestCase::DoRun(), ns3::Kun2600MhzPropagationLossModelTestCase::DoRun(), ns3::OkumuraHataPropagationLossModelTestCase::DoRun(), ns3::LenaHarqTestCase::DoRun(), ns3::LenaDataPhyErrorModelTestCase::DoRun(), ns3::LenaRrFfMacSchedulerTestCase::DoRun(), ns3::BuildingsPathlossTestCase::DoRun(), ns3::BuildingsShadowingTestCase::DoRun(), ns3::LenaPfFfMacSchedulerTestCase1::DoRun(), ns3::LenaFdBetFfMacSchedulerTestCase1::DoRun(), LenaFdMtFfMacSchedulerTestCase::DoRun(), ns3::LenaFdTbfqFfMacSchedulerTestCase1::DoRun(), ns3::LenaTdTbfqFfMacSchedulerTestCase1::DoRun(), ns3::LenaPssFfMacSchedulerTestCase1::DoRun(), ns3::LenaTdBetFfMacSchedulerTestCase1::DoRun(), LenaTdMtFfMacSchedulerTestCase::DoRun(), LenaTtaFfMacSchedulerTestCase::DoRun(), ns3::LteLinkAdaptationTestCase::DoRun(), ns3::AcousticModemEnergyTestCase::DoRun(), ns3::LteInterferenceTestCase::DoRun(), ns3::LtePathlossModelSystemTestCase::DoRun(), ns3::LteEnbAntennaTestCase::DoRun(), ns3::LenaDlCtrlPhyErrorModelTestCase::DoRun(), ns3::LenaPfFfMacSchedulerTestCase2::DoRun(), ns3::LenaFdBetFfMacSchedulerTestCase2::DoRun(), ns3::LenaTdBetFfMacSchedulerTestCase2::DoRun(), ns3::LenaFdTbfqFfMacSchedulerTestCase2::DoRun(), ns3::LenaPssFfMacSchedulerTestCase2::DoRun(), ns3::LenaTdTbfqFfMacSchedulerTestCase2::DoRun(), ns3::LteEarfcnDlTestCase::DoRun(), ns3::SpectrumIdealPhyTestCase::DoRun(), TimesWithSignsTestCase::DoRun(), ns3::LteEarfcnUlTestCase::DoRun(), FiveIntegersAverageTestCase::DoRun(), FiveIntegersTestCase::DoRun(), FiveDoublesAverageTestCase::DoRun(), FiveDoublesTestCase::DoRun(), RandomVariableStreamConstantTestCase::DoRun(), RandomVariableStreamSequentialTestCase::DoRun(), RandomVariableStreamNormalTestCase::DoRun(), RandomVariableStreamNormalAntitheticTestCase::DoRun(), RandomVariableStreamExponentialTestCase::DoRun(), RandomVariableStreamExponentialAntitheticTestCase::DoRun(), RandomVariableStreamParetoTestCase::DoRun(), RandomVariableStreamParetoAntitheticTestCase::DoRun(), RandomVariableStreamWeibullTestCase::DoRun(), RandomVariableStreamWeibullAntitheticTestCase::DoRun(), RandomVariableStreamLogNormalTestCase::DoRun(), RandomVariableStreamLogNormalAntitheticTestCase::DoRun(), RandomVariableStreamGammaTestCase::DoRun(), RandomVariableStreamGammaAntitheticTestCase::DoRun(), RandomVariableStreamErlangTestCase::DoRun(), RandomVariableStreamErlangAntitheticTestCase::DoRun(), RandomVariableStreamZipfTestCase::DoRun(), RandomVariableStreamZipfAntitheticTestCase::DoRun(), RandomVariableStreamZetaTestCase::DoRun(), RandomVariableStreamZetaAntitheticTestCase::DoRun(), RandomVariableStreamDeterministicTestCase::DoRun(), RandomVariableStreamEmpiricalTestCase::DoRun(), and RandomVariableStreamEmpiricalAntitheticTestCase::DoRun().
| #define NS_TEST_ASSERT_MSG_EQ_TOL_INTERNAL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
Test that actual and expected (limit) values are equal to plus or minus some tolerance and report and abort if not.
Check to see if the expected (limit) value is equal to the actual value found in a test case to some tolerance. This is not the same thing as asking if two floating point are equal to within some epsilon, but is useful for that case. This assertion is geared toward more of a measurement problem. Consider measuring a physical rod of some kind that you have ordered. You need to determine if it is "good." You won't measure the rod to an arbitrary precision of sixteen significant figures, you will measure the rod to determine if its length is within the tolerances you provided. For example, 12.00 inches plus or minus .005 inch may be just fine.
In ns-3, you might want to measure a signal to noise ratio and check to see if the answer is what you expect. If you naively measure (double)1128.93 and compare this number with a constant 1128.93 you are almost certainly going to have your test fail because of floating point rounding errors. We provide a floating point comparison function ns3::TestDoubleIsEqual() but you will probably quickly find that is not what you want either. It may turn out to be the case that when you measured an snr that printed as 1128.93, what was actually measured was something more like 1128.9287653857625442 for example. Given that the double epsilon is on the order of 0.0000000000000009, you would need to provide sixteen significant figures of expected value for this kind of test to pass even with a typical test for floating point "approximate equality." That is clearly not required or desired. You really want to be able to provide 1128.93 along with a tolerance just like you provided 12 inches +- 0.005 inch above.
This assertion is designed for real measurements by taking into account measurement tolerances. By doing so it also automatically compensates for floating point rounding errors. If you really want to check floating point equality down to the numeric_limits<double>::epsilon () range, consider using ns3::TestDoubleIsEqual().
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| tol | Tolerance of the test. | 
| msg | Message that is output if the test does not pass. | 
This function returns a boolean value.
Definition at line 391 of file test.h.
Referenced by BasicEnergyUpdateTest::StateSwitchTest(), and BatteryLifetimeTest::VariableLoadTest().
| #define NS_TEST_ASSERT_MSG_EQ_TOL_RETURNS_BOOL_INTERNAL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_GT | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_GT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual value is greater than a limit and report and abort if not.
Check to see if the actual value found in a test case is greater than the limit value. If the actual value is greater nothing happens, but if the check fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the limit value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 758 of file test.h.
Referenced by ns3::LteX2HandoverTestCase::CheckStatsAWhileAfterHandover(), ManyUniformRandomVariablesOneGetValueCallTestCase::DoRun(), OneUniformRandomVariableManyGetValueCallsTestCase::DoRun(), WifiMsduAggregatorThroughputTest::DoRun(), and ns3::RandomRoomPositionAllocatorTestCase::DoRun().
| #define NS_TEST_ASSERT_MSG_GT_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_LT | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_LT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual value is less than a limit and report and abort if not.
Check to see if the actual value found in a test case is less than the limit value. If the actual value is lesser nothing happens, but if the check fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the limit value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 673 of file test.h.
Referenced by ManyUniformRandomVariablesOneGetValueCallTestCase::DoRun(), OneUniformRandomVariableManyGetValueCallsTestCase::DoRun(), RngUniformTestCase::DoRun(), ns3::RandomRoomPositionAllocatorTestCase::DoRun(), RandomVariableStreamUniformTestCase::DoRun(), RngNormalTestCase::DoRun(), RandomVariableStreamUniformAntitheticTestCase::DoRun(), RngExponentialTestCase::DoRun(), RngParetoTestCase::DoRun(), RandomVariableStreamNormalTestCase::DoRun(), RandomVariableStreamNormalAntitheticTestCase::DoRun(), RandomVariableStreamExponentialTestCase::DoRun(), RandomVariableStreamExponentialAntitheticTestCase::DoRun(), RandomVariableStreamParetoTestCase::DoRun(), RandomVariableStreamParetoAntitheticTestCase::DoRun(), RandomVariableStreamWeibullTestCase::DoRun(), RandomVariableStreamWeibullAntitheticTestCase::DoRun(), RandomVariableStreamLogNormalTestCase::DoRun(), RandomVariableStreamLogNormalAntitheticTestCase::DoRun(), RandomVariableStreamGammaTestCase::DoRun(), RandomVariableStreamGammaAntitheticTestCase::DoRun(), RandomVariableStreamErlangTestCase::DoRun(), RandomVariableStreamErlangAntitheticTestCase::DoRun(), ns3::LteHandoverDelayTestCase::EnbHandoverEndOkCallback(), and ns3::LteHandoverDelayTestCase::UeHandoverEndOkCallback().
| #define NS_TEST_ASSERT_MSG_LT_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_NE | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_NE_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are not equal and report and abort if not.
Check to see if the expected (limit) value is not equal to the actual value found in a test case. If the two values are not equal nothing happens, but if the comparison fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the value that actual is tested against. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 524 of file test.h.
Referenced by ns3::LteRrcConnectionEstablishmentTestCase::CheckConnected(), ns3::LteX2HandoverTestCase::CheckConnected(), BufferTest::DoRun(), ns3::RocketfuelTopologyReaderTest::DoRun(), SwitchFlowTableTestCase::DoRun(), ns3::AnimationInterfaceTestCase::DoRun(), ns3::CreateObjectTestCase::DoRun(), ns3::AggregateObjectTestCase::DoRun(), RandomVariableStreamConstantTestCase::DoRun(), AttributeTestCase< T >::DoRun(), ns3::ObjectFactoryTestCase::DoRun(), FileHeaderTestCase::DoRun(), RecordHeaderTestCase::DoRun(), RandomVariableStreamAttributeTestCase::DoRun(), ObjectVectorAttributeTestCase::DoRun(), ObjectMapAttributeTestCase::DoRun(), IntegerTraceSourceAttributeTestCase::DoRun(), IntegerTraceSourceTestCase::DoRun(), TracedCallbackTestCase::DoRun(), PointerAttributeTestCase::DoRun(), and CallbackValueTestCase::DoRun().
| #define NS_TEST_ASSERT_MSG_NE_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are not equal and report and abort if not.
Check to see if the expected (limit) value is not equal to the actual value found in a test case. If the two values are equal nothing happens, but if the comparison fails, an error is reported in a consistent way and the execution of the current test case is aborted.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| msg | Message that is output if the test does not pass. | 
This function returns a boolean value.
Definition at line 577 of file test.h.
Referenced by ns3::Ns2MobilityHelperTest::CheckInitialPositions(), and BasicEnergyUpdateTest::StateSwitchTest().
| #define NS_TEST_ASSERT_MSG_NE_RETURNS_BOOL_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
| #define NS_TEST_EXPECT_MSG_EQ | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_EXPECT_MSG_EQ_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are equal and report if not.
Check to see if the expected (lmit) value is equal to the actual value found in a test case. If the two values are equal nothing happens, but if the comparison fails, an error is reported in a consistent way. EXPECT* macros do not return if an error is detected.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 229 of file test.h.
Referenced by Int64x64FracTestCase::CheckFrac(), ns3::Ns2MobilityHelperTest::CheckInitialPositions(), ns3::aodv::AodvRqueueTest::CheckSizeLimit(), ns3::dsr::DsrSendBuffTest::CheckSizeLimit(), Int64x64InputTestCase::CheckString(), Int64x64InputOutputTestCase::CheckString(), ns3::aodv::AodvRqueueTest::CheckTimeout(), ns3::dsr::DsrSendBuffTest::CheckTimeout(), ns3::aodv::NeighborTest::CheckTimeout1(), ns3::aodv::IdCacheTest::CheckTimeout1(), ns3::aodv::NeighborTest::CheckTimeout2(), ns3::aodv::IdCacheTest::CheckTimeout2(), ns3::aodv::NeighborTest::CheckTimeout3(), ns3::aodv::IdCacheTest::CheckTimeout3(), ns3::Ns2MobilityHelperTest::CourseChange(), ns3::WaypointMobilityModelNotifyTest::CourseChangeCallback(), HwmpReactiveRegressionTest::CreateDevices(), ns3::olsr::TcRegressionTest::CreateNodes(), PacketTest::DoCheck(), BufferTest::DoRun(), NetworkNumberAllocatorTestCase::DoRun(), DropTailQueueTestCase::DoRun(), ns3::HistogramTestCase::DoRun(), NetworkNumber6AllocatorTestCase::DoRun(), NetworkAllocatorHelperTestCase::DoRun(), SimulatorEventsTestCase::DoRun(), ns3::aodv::NeighborTest::DoRun(), RttTestCase::DoRun(), ns3::EventGarbageCollectorTestCase::DoRun(), ns3::RocketfuelTopologyReaderTest::DoRun(), TestEmptyOptionField::DoRun(), ns3::aodv::IdCacheTest::DoRun(), ns3::olsr::OlsrMprTestCase::DoRun(), Ns3WimaxFragmentationTestCase::DoRun(), PtrTestCase::DoRun(), Ns3WimaxNetworkEntryTestCase::DoRun(), DualStackTestCase::DoRun(), ThreadedSimulatorEventsTestCase::DoRun(), ns3::dsr::DsrFsHeaderTest::DoRun(), TcpTestCase::DoRun(), PacketBufferingCaseA::DoRun(), AddressAllocator6TestCase::DoRun(), AddressAllocatorHelperTestCase::DoRun(), Ipv6RawSocketImplTest::DoRun(), AddressAllocatorTestCase::DoRun(), Ipv4HeaderTest::DoRun(), Ipv4RawSocketImplTest::DoRun(), TestOptionWithoutAlignment::DoRun(), Ipv4FragmentationTest::DoRun(), ns3::dsr::DsrRreqHeaderTest::DoRun(), ns3::aodv::TypeHeaderTest::DoRun(), ns3::DsdvTableTestCase::DoRun(), Ipv6FragmentationTest::DoRun(), UdpSocketLoopbackTest::DoRun(), Ns3WimaxManagementConnectionsTestCase::DoRun(), ResetAllocatorHelperTestCase::DoRun(), ns3::aodv::RreqHeaderTest::DoRun(), NetworkAndAddress6TestCase::DoRun(), NetworkAndAddressTestCase::DoRun(), ns3::dsr::DsrRrepHeaderTest::DoRun(), TestOptionWithAlignment::DoRun(), PacketBufferingCaseB::DoRun(), Udp6SocketLoopbackTest::DoRun(), ns3::QosUtilsIsOldPacketTest::DoRun(), ExampleAddress6GeneratorTestCase::DoRun(), ns3::aodv::RrepHeaderTest::DoRun(), ns3::dsr::DsrSRHeaderTest::DoRun(), ExampleAddressGeneratorTestCase::DoRun(), TestFulfilledAlignment::DoRun(), UdpSocketImplTest::DoRun(), PacketTest::DoRun(), AddressCollision6TestCase::DoRun(), ns3::aodv::RrepAckHeaderTest::DoRun(), ns3::dot11s::PeerLinkFrameStartTest::DoRun(), CtrlBAckResponseHeaderTest::DoRun(), ns3::dsr::DsrRerrHeaderTest::DoRun(), ns3::aodv::RerrHeaderTest::DoRun(), AddressCollisionTestCase::DoRun(), PacketMetadataTest::DoRun(), ns3::dsr::DsrAckReqHeaderTest::DoRun(), ns3::aodv::QueueEntryTest::DoRun(), ns3::aodv::AodvRqueueTest::DoRun(), ns3::dsr::DsrAckHeaderTest::DoRun(), ns3::dsr::DsrCacheEntryTest::DoRun(), ns3::dsr::DsrSendBuffTest::DoRun(), ns3::aodv::AodvRtableEntryTest::DoRun(), Udp6SocketImplTest::DoRun(), ns3::aodv::AodvRtableTest::DoRun(), ns3::dsr::DsrRreqTableTest::DoRun(), DiffTestCase::DoRun(), Ipv6RawSocketImplTest::DoSendData(), Ipv6PacketInfoTagTest::DoSendData(), Ipv4RawSocketImplTest::DoSendData(), Ipv4PacketInfoTagTest::DoSendData(), UdpSocketImplTest::DoSendData(), Udp6SocketImplTest::DoSendData(), Ipv4RawSocketImplTest::DoSendData_IpHdr(), Ipv4HeaderTest::DoSendData_IpHdr_Dscp(), ns3::DcfManagerTest::EndTest(), Ns3TcpStateTestCase::Ipv4L3Tx(), Ns3TcpLossTestCase::Ipv4L3Tx(), Ns3TcpInteroperabilityTestCase::Ipv4L3Tx(), ns3::DcfManagerTest::NotifyAccessGranted(), ns3::DcfManagerTest::NotifyChannelSensing(), ns3::DcfManagerTest::NotifyChannelSwitching(), ns3::DcfManagerTest::NotifyCollision(), ns3::DcfManagerTest::NotifyInternalCollision(), Ipv6RawSocketImplTest::ReceivePkt2(), RedQueueTestCase::RunRedTest(), TcpTestCase::ServerHandleRecv(), TcpTestCase::ServerHandleSend(), TcpTestCase::SourceHandleRecv(), TcpTestCase::SourceHandleSend(), ns3::flame::FlameRtableTest::TestExpire(), ns3::dot11s::HwmpRtableTest::TestExpire(), ns3::flame::FlameRtableTest::TestLookup(), ns3::dot11s::HwmpRtableTest::TestLookup(), WaypointInitialPositionIsWaypoint::TestNumWaypoints(), and ns3::dot11s::HwmpRtableTest::TestPrecursorFind().
| #define NS_TEST_EXPECT_MSG_EQ_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Required to avoid use of return statement which allows use in methods (esp. callbacks) returning void.
Definition at line 185 of file test.h.
Referenced by PacketTest::DoCheck().
| #define NS_TEST_EXPECT_MSG_EQ_TOL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg | |||
| ) | NS_TEST_EXPECT_MSG_EQ_TOL_INTERNAL (actual, limit, tol, msg, __FILE__, __LINE__) | 
Test that actual and expected (limit) values are equal to plus or minus some tolerance and report if not.
Check to see if the expected (limit) value is equal to the actual value found in a test case to some tolerance. This is not the same thing as asking if two floating point are equal to within some epsilon, but is useful for that case. This assertion is geared toward more of a measurement problem. Consider measuring a physical rod of some kind that you have ordered. You need to determine if it is "good." You won't measure the rod to an arbitrary precision of sixteen significant figures, you will measure the rod to determine if its length is within the tolerances you provided. For example, 12.00 inches plus or minus .005 inch may be just fine.
In ns-3, you might want to measure a signal to noise ratio and check to see if the answer is what you expect. If you naively measure (double)1128.93 and compare this number with a constant 1128.93 you are almost certainly going to have your test fail because of floating point rounding errors. We provide a floating point comparison function ns3::TestDoubleIsEqual() but you will probably quickly find that is not what you want either. It may turn out to be the case that when you measured an snr that printed as 1128.93, what was actually measured was something more like 1128.9287653857625442 for example. Given that the double epsilon is on the order of 0.0000000000000009, you would need to provide sixteen significant figures of expected value for this kind of test to pass even with a typical test for floating point "approximate equality." That is clearly not required or desired. You really want to be able to provide 1128.93 along with a tolerance just like you provided 12 inches +- 0.005 inch above.
This assertion is designed for real measurements by taking into account measurement tolerances. By doing so it also automatically compensates for floating point rounding errors. If you really want to check floating point equality down to the numeric_limits<double>::epsilon () range, consider using ns3::TestDoubleIsEqual().
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the expected value of the test. | 
| tol | Tolerance of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 470 of file test.h.
Referenced by ns3::SteadyStateRandomWaypointTest::DistribCompare(), ns3::HistogramTestCase::DoRun(), ns3::OneVectorConstructorTestCase::DoRun(), ns3::DegreesToRadiansTestCase::DoRun(), ns3::IsotropicAntennaModelTestCase::DoRun(), BasicRandomNumberTestCase::DoRun(), FriisPropagationLossModelTestCase::DoRun(), ns3::CosineAntennaModelTestCase::DoRun(), ns3::ParabolicAntennaModelTestCase::DoRun(), ns3::RadiansToDegreesTestCase::DoRun(), ns3::TwoVectorsConstructorTestCase::DoRun(), TwoRayGroundPropagationLossModelTestCase::DoRun(), LogDistancePropagationLossModelTestCase::DoRun(), and RangePropagationLossModelTestCase::DoRun().
| #define NS_TEST_EXPECT_MSG_EQ_TOL_INTERNAL | ( | actual, | |
| limit, | |||
| tol, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Required to avoid use of return statement which allows use in methods (esp. callbacks) returning void.
Definition at line 400 of file test.h.
Referenced by WaypointLazyNotifyFalse::CourseChangeCallback(), WaypointLazyNotifyTrue::CourseChangeCallback(), WaypointLazyNotifyFalse::TestXPosition(), WaypointLazyNotifyTrue::TestXPosition(), WaypointInitialPositionIsWaypoint::TestXPosition(), and WaypointMobilityModelViaHelper::TestXPosition().
| #define NS_TEST_EXPECT_MSG_GT | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_EXPECT_MSG_GT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual value is greater than a limit and report if not.
Check to see if the actual value found in a test case is greater than the limit value. If the actual value is greater nothing happens, but if the check fails, an error is reported in a consistent way. EXPECT* macros do not return if an error is detected.
The message is interpreted as a stream.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the limit value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 799 of file test.h.
Referenced by RedQueueTestCase::RunRedTest().
| #define NS_TEST_EXPECT_MSG_GT_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Required to avoid use of return statement which allows use in methods (callbacks) returning void.
| #define NS_TEST_EXPECT_MSG_LT | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_EXPECT_MSG_LT_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual value is less than a limit and report if not.
Check to see if the actual value found in a test case is less than the limit value. If the actual value is lesser nothing happens, but if the check fails, an error is reported in a consistent way. EXPECT* macros do not return if an error is detected.
The message is interpreted as a stream.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the limit value of the test. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 714 of file test.h.
Referenced by ns3::Ns2MobilityHelperTest::CourseChange(), ns3::CosineAntennaModelTestCase::DoRun(), and ns3::ParabolicAntennaModelTestCase::DoRun().
| #define NS_TEST_EXPECT_MSG_LT_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Required to avoid use of return statement which allows use in methods (callbacks) returning void.
| #define NS_TEST_EXPECT_MSG_NE | ( | actual, | |
| limit, | |||
| msg | |||
| ) | NS_TEST_EXPECT_MSG_NE_INTERNAL (actual, limit, msg, __FILE__, __LINE__) | 
Test that an actual and expected (limit) value are not equal and report if not.
Check to see if the expected (limit) value is not equal to the actual value found in a test case. If the two values are not equal nothing happens, but if the comparison fails, an error is reported in a consistent way. EXPECT* macros do not return if an error is detected.
The message is interpreted as a stream, for example:
is legal.
| actual | Expression for the actual value found during the test. | 
| limit | Expression for the value that actual is tested against. | 
| msg | Message that is output if the test does not pass. | 
Definition at line 629 of file test.h.
Referenced by PacketTest::DoCheck(), and RedQueueTestCase::RunRedTest().
| #define NS_TEST_EXPECT_MSG_NE_INTERNAL | ( | actual, | |
| limit, | |||
| msg, | |||
| file, | |||
| line | |||
| ) | 
Required to avoid use of return statement which allows use in methods (callbacks) returning void.