--- trunk/test/math/VectorTestCase.cpp 2004/10/19 04:21:07 102 +++ trunk/test/math/VectorTestCase.cpp 2004/10/25 22:46:19 151 @@ -187,25 +187,34 @@ void VectorTestCase::testAccessEntries(){ void VectorTestCase::testAccessEntries(){ //test [] operator - CPPUNIT_ASSERT(zero[0] == 0.0); - CPPUNIT_ASSERT(one[0] == 1.0); - CPPUNIT_ASSERT(v3[0] == 4.0); + CPPUNIT_ASSERT_DOUBLES_EQUAL(zero[0], 0.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(one[0] , 1.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(v3[0] , 4.0, oopse::epsilon); //test () operator - CPPUNIT_ASSERT(v3(0) != 1.0); + CPPUNIT_ASSERT_DOUBLES_EQUAL(v3(0) , 4.0, oopse::epsilon); + Vec4 a1; + double *pa1 = a1.getArrayPointer(); + + pa1[0] = 4.0; + pa1[1] = 1.0; + pa1[2] = 3.0; + pa1[3] = 2.0; + + CPPUNIT_ASSERT(a1 == v3); } void VectorTestCase::testOtherMemberFunctions(){ //test length() - CPPUNIT_ASSERT(zero.length() == 0.0); - CPPUNIT_ASSERT(one.length() == 2.0); - CPPUNIT_ASSERT(v2.length() == sqrt(14.0)); + CPPUNIT_ASSERT_DOUBLES_EQUAL(zero.length(), 0.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(one.length(), 2.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(v2.length(), sqrt(14.0), oopse::epsilon); //test lengthSquare() - CPPUNIT_ASSERT(zero.lengthSquare() == 0.0); - CPPUNIT_ASSERT(one.lengthSquare() == 4.0); - CPPUNIT_ASSERT(v2.length() == 14.0); + CPPUNIT_ASSERT_DOUBLES_EQUAL(zero.lengthSquare(), 0.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(one.lengthSquare(), 4.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(v2.lengthSquare(), 14.0, oopse::epsilon); //test normalize() Vec4 a1 = one; @@ -218,20 +227,26 @@ void VectorTestCase::testOtherMemberFunctions(){ //test isNormalized(); CPPUNIT_ASSERT(a1.isNormalized()); CPPUNIT_ASSERT(!one.isNormalized()); - + //test getArray + double tempV[4]; + v3.getArray(tempV); + CPPUNIT_ASSERT_DOUBLES_EQUAL(tempV[0], v3[0], oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(tempV[1], v3[1], oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(tempV[2], v3[2], oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(tempV[3], v3[3], oopse::epsilon); } void VectorTestCase::testOtherTemplateFunctions(){ //test dot - CPPUNIT_ASSERT(dot(one, two) == 8.0); - CPPUNIT_ASSERT(dot(v1, v3) == 20.0); + CPPUNIT_ASSERT_DOUBLES_EQUAL(dot(one, two), 8.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(dot(v1, v3), 20.0, oopse::epsilon); //test distance - CPPUNIT_ASSERT(distance(one, two) == 2.0); - CPPUNIT_ASSERT(distance(v1, v2) == sqrt(56.0)); + CPPUNIT_ASSERT_DOUBLES_EQUAL(distance(one, two), 2.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(distance(v1, v2), sqrt(56.0), oopse::epsilon); //test distanceSquare - CPPUNIT_ASSERT(distanceSquare(one, two) == 4.0); - CPPUNIT_ASSERT(distanceSquare(v1, v2) == 56); + CPPUNIT_ASSERT_DOUBLES_EQUAL(distanceSquare(one, two), 4.0, oopse::epsilon); + CPPUNIT_ASSERT_DOUBLES_EQUAL(distanceSquare(v1, v2), 56, oopse::epsilon); }