117 lines
3.0 KiB
C++
117 lines
3.0 KiB
C++
#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_ss_square_distance(void)
|
|
{
|
|
AccessPoint ap1(Point3D(1,2,3), "aa:bb:cc:dd:ee:ff") ;
|
|
CalibrationRequest calibrationrequest1 ;
|
|
Measurement measurement1(&ap1) ;
|
|
measurement1.add_ss(-78) ;
|
|
std::tr1::unordered_map<std::string, Measurement> measurements ;
|
|
measurements["aa:bb:cc:dd:ee:ff"] = measurement1 ;
|
|
calibrationrequest1.set_measurements(measurements) ;
|
|
ReferencePoint referencepoint1 ;
|
|
referencepoint1.add_request(&calibrationrequest1) ;
|
|
TS_ASSERT_EQUALS(0, referencepoint1.ss_square_distance(
|
|
calibrationrequest1)) ;
|
|
|
|
/* Distance computation:
|
|
* (-42 - (-78))^2 == 1296
|
|
*/
|
|
CalibrationRequest calibrationrequest2 ;
|
|
measurement1.clear() ;
|
|
measurement1.add_ss(-42) ;
|
|
measurements["aa:bb:cc:dd:ee:ff"] = measurement1 ;
|
|
calibrationrequest2.set_measurements(measurements) ;
|
|
TS_ASSERT_EQUALS(1296, referencepoint1.ss_square_distance(
|
|
calibrationrequest2)) ;
|
|
}
|
|
|
|
|
|
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(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) ;
|
|
}
|
|
|
|
} ;
|