test.cpp

Go to the documentation of this file.
00001 #ifndef KDAB_NO_UNIT_TESTS
00002 
00003 #include "test.h"
00004 
00005 #ifdef TEMPORARILY_REMOVED
00006 #include <trinav/ascshared/libfakes/fakes.h>
00007 #endif
00008 
00009 #include <cmath>
00010 #include <limits>
00011 
00012 KDAB::UnitTest::Test::Test( const std::string & n )
00013     : mName( n ), mFailed( 0 ), mSucceeded( 0 ) {}
00014 
00015 void KDAB::UnitTest::Test::_assertNotNull( const void * x, const char * expression, const char * file, unsigned int line ) {
00016     if ( x ) success();
00017     else fail( file, line ) << '"' << expression << "\" is NULL, expected non-NULL" << std::endl;
00018 }
00019 
00020 void KDAB::UnitTest::Test::_assertNull( const void * x, const char * expression, const char * file, unsigned int line ) {
00021     if ( !x ) success();
00022     else fail( file, line ) << '"' << expression << "\" is not NULL, expected NULL" << std::endl;
00023 }
00024 
00025 #if 0
00026 void KDAB::UnitTest::Test::_assertIsNaN( double d, const char * expression, const char * file, unsigned int line ) {
00027     if ( std::isnan( d ) ) success();
00028     else fail( file, line ) << '"' << expression << "\" yielded " << d << "; expected NaN" << std::endl;
00029 }
00030 
00031 void KDAB::UnitTest::Test::_assertIsNotNaN( double d, const char * expression, const char * file, unsigned int line ) {
00032     if ( !std::isnan( d ) ) success();
00033     else fail( file, line ) << '"' << expression << "\" yielded nan; expected something else" << std::endl;
00034 }
00035 #endif
00036 
00037 void KDAB::UnitTest::Test::_assertTrue( bool x, const char * expression, const char * file, unsigned int line ) {
00038     if ( x ) success();
00039     else fail( file, line ) << '"' << expression << "\" != TRUE" << std::endl;
00040 }
00041 
00042 void KDAB::UnitTest::Test::_assertFalse( bool x, const char * expression, const char * file, unsigned int line ) {
00043     if ( !x ) success();
00044     else fail( file, line ) << '"' << expression << "\" != FALSE" << std::endl;
00045 }
00046 
00047 void KDAB::UnitTest::Test::_assertEqualWithEpsilons( float x1, float x2, int prec, const char * expr1, const char * expr2, const char * exprP, const char * file, unsigned int line ) {
00048     if ( qAbs( x1/x2 - 1.0f ) <= prec * std::numeric_limits<float>::epsilon() ) success();
00049     else fail( file, line ) << x1 << " (" << expr1 << ") deviates from expected "
00050                             << x2 << " (" << expr2 << ") by more than "
00051                             << prec << " (" << exprP << ") epsilons." << std::endl;
00052 }
00053 
00054 void KDAB::UnitTest::Test::_assertEqualWithEpsilons( double x1, double x2, int prec, const char * expr1, const char * expr2, const char * exprP, const char * file, unsigned int line ) {
00055     if ( qAbs( x1/x2 - 1.0 ) <= prec * std::numeric_limits<double>::epsilon() ) success();
00056     else fail( file, line ) << x1 << " (" << expr1 << ") deviates from expected "
00057                             << x2 << " (" << expr2 << ") by more than "
00058                             << prec << " (" << exprP << ") epsilons." << std::endl;
00059 }
00060 
00061 void KDAB::UnitTest::Test::_assertEqualWithEpsilons( long double x1, long double x2, int prec, const char * expr1, const char * expr2, const char * exprP, const char * file, unsigned int line ) {
00062     if ( qAbs( x1/x2 - 1.0l ) <= prec * std::numeric_limits<long double>::epsilon() ) success();
00063     else fail( file, line ) << x1 << " (" << expr1 << ") deviates from expected "
00064                             << x2 << " (" << expr2 << ") by more than "
00065                             << prec << " (" << exprP << ") epsilons." << std::endl;
00066 }
00067 
00068 std::ostream & KDAB::UnitTest::Test::fail( const char * file, unsigned int line ) {
00069     ++mFailed;
00070     return std::cerr << "FAIL: " << file << ':' << line << ": ";
00071 }
00072 
00073 #endif // KDAB_NO_UNIT_TESTS

Generated on Thu Mar 4 23:19:13 2010 for KD Chart 2 by  doxygen 1.5.4