owlps/owlps-positioning/tests/referencepoint_test.hh

90 lines
2.0 KiB
C++
Raw Normal View History

#include <cxxtest/TestSuite.h>
#include "referencepoint.hh"
#include "calibrationrequest.hh"
class ReferencePoint_test: public CxxTest::TestSuite
{
public:
void test_constructors(void)
{
// Default constructor
ReferencePoint rp00 ;
ReferencePoint rp01(0, 0, 0) ;
TS_ASSERT_EQUALS(rp00, rp01) ;
// Copy constructor
ReferencePoint rp1(1, 2, 3) ;
ReferencePoint rp2(rp1) ;
TS_ASSERT_EQUALS(rp1, rp2) ;
// Point3D copy constructor
Point3D p0(5, 3, 8) ;
ReferencePoint rp4(p0) ;
TS_ASSERT_EQUALS(p0, rp4) ;
// 3-float array constructor
float coord[3] = {1, 2, 3} ;
ReferencePoint rp3(coord) ;
TS_ASSERT_EQUALS(rp1, rp3) ;
}
void test_accessors(void)
{
// Simple read accessors
ReferencePoint rp1(1, 3, 5) ;
TS_ASSERT_EQUALS(rp1.get_x(), 1) ;
TS_ASSERT_EQUALS(rp1.get_y(), 3) ;
TS_ASSERT_EQUALS(rp1.get_z(), 5) ;
// Write & read accessors
CalibrationRequest calibrationrequest1, calibrationrequest2, calibrationrequest3 ;
rp1.add_request(&calibrationrequest1) ;
rp1.add_request(&calibrationrequest2) ;
rp1.add_request(&calibrationrequest3) ;
std::vector<CalibrationRequest*> vcr1 ;
vcr1.push_back(&calibrationrequest1) ;
vcr1.push_back(&calibrationrequest2) ;
vcr1.push_back(&calibrationrequest3) ;
TS_ASSERT_EQUALS(rp1.get_requests(), vcr1) ;
rp1.set_x(42) ;
TS_ASSERT_EQUALS(rp1.get_x(), 42) ;
rp1.set_y(321) ;
TS_ASSERT_EQUALS(rp1.get_y(), 321) ;
rp1.set_z(98) ;
TS_ASSERT_EQUALS(rp1.get_z(), 98) ;
}
void test_operators(void)
{
// ==
ReferencePoint rp1(42, 21, 19) ;
ReferencePoint rp2(42, 21, 19) ;
TS_ASSERT_EQUALS(rp1, rp2) ;
// !=
ReferencePoint rp3(1, 4, 7) ;
TS_ASSERT_DIFFERS(rp1, rp3) ;
// =
rp2 = rp3 ;
TS_ASSERT_EQUALS(rp2, rp3) ;
// <
TS_ASSERT_LESS_THAN(rp2, rp1) ;
// <=
TS_ASSERT_LESS_THAN_EQUALS(rp2, rp1) ;
// >
TS_ASSERT(rp1 > rp2) ;
// >=
TS_ASSERT(rp1 >= rp2) ;
}
} ;