📄 test_tools_test.cpp
字号:
unit_test_log::instance().set_log_threshold_level( log_all_errors );
int i=1;
int j=2;
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL( i, j ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test i == j failed [1 != 2]\n", 2 ) )
);
char const* str1 = "test1";
char const* str2 = "test12";
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL( str1, str2 ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test str1 == str2 failed [test1 != test12]\n", 2 ) )
);
str1 = NULL;
str2 = NULL;
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL( str1, str2 ),
output.is_empty()
);
str1 = "test";
str2 = NULL;
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL( str1, str2 ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test str1 == str2 failed [test != null string]\n", 2 ) )
);
B b1(1);
B b2(2);
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL( b1, b2 ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test b1 == b2 failed [B(1) != B(2)]\n", 2 ) )
);
}
//____________________________________________________________________________//
bool is_even( int i ) { return i%2 == 0; }
int foo( int arg, int mod ) { return arg % mod; }
BOOST_TEST_DONT_PRINT_LOG_VALUE( std::list<int> )
extended_predicate_value
compare_lists( std::list<int> const& l1, std::list<int> const& l2 )
{
if( l1.size() != l2.size() ) {
extended_predicate_value res( false );
res.p_message.reset( new boost::wrap_stringstream );
*res.p_message << " Different sizes [" << l1.size() << "!=" << l2.size() << "]";
return res;
}
return true;
}
void
test_BOOST_CHECK_PREDICATE()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_CHECK_PREDICATE" << '\"' <<
CHECK_TOOL_USAGE(
BOOST_CHECK_PREDICATE( &is_even, 1, (14) ),
output.is_empty()
);
int i = 17;
CHECK_TOOL_USAGE(
BOOST_CHECK_PREDICATE( &is_even, 1, (i) ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test &is_even(i) failed for 17\n", 2 ) )
);
CHECK_TOOL_USAGE(
BOOST_CHECK_PREDICATE( std::not_equal_to<int>(), 2, (i,17) ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test std::not_equal_to<int>()(i, 17) failed for (17, 17)\n", 2 ) )
);
CHECK_TOOL_USAGE(
BOOST_CHECK_PREDICATE( boost::bind( &is_even, boost::bind( &foo, _1, _2 ) ), 2, (i,15) ),
output.is_empty()
);
std::list<int> l1, l2, l3;
l1.push_back( 1 );
l3.push_back( 1 );
l1.push_back( 2 );
l3.push_back( 3 );
CHECK_TOOL_USAGE(
BOOST_CHECK_PREDICATE( &compare_lists, 2, (l1,l2) ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test &compare_lists(l1, l2) failed for (, ) Different sizes [2!=0]\n", 2 ) )
);
}
//____________________________________________________________________________//
void
test_BOOST_REQUIRE_PREDICATE()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_REQUIRE_PREDICATE" << '\"' <<
int arg1 = 1;
int arg2 = 2;
CHECK_CRITICAL_TOOL_USAGE(
BOOST_REQUIRE_PREDICATE( std::less_equal<int>(), 2, ( arg1, arg2 ) ),
output.is_empty(), false
);
CHECK_CRITICAL_TOOL_USAGE(
BOOST_REQUIRE_PREDICATE( std::less_equal<int>(), 2, ( arg2, arg1 ) ),
false, output.is_equal( CHECK_PATTERN(
"fatal error in " TEST_CASE_NAME ": test std::less_equal<int>()(arg2, arg1) "
"failed for (" << arg2 << ", " << arg1 << ")\n", 4 ) )
);
}
//____________________________________________________________________________//
void
test_BOOST_ERROR()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_ERROR" << '\"' <<
unit_test_log::instance().set_log_threshold_level( log_all_errors );
CHECK_TOOL_USAGE(
BOOST_ERROR( "Fail to miss an error" ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": Fail to miss an error\n", 2 ) )
);
CHECK_CRITICAL_TOOL_USAGE(
BOOST_FAIL( "No! No! Show must go on." ),
false, output.is_equal( CHECK_PATTERN( "fatal error in " TEST_CASE_NAME ": No! No! Show must go on.\n", 2 ) )
);
}
//____________________________________________________________________________//
struct my_exception {
explicit my_exception( int ec = 0 ) : m_error_code( ec ) {}
int m_error_code;
};
bool is_critical( my_exception const& ex ) { return ex.m_error_code < 0; }
void
test_BOOST_CHECK_THROW()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_CHECK_THROW" << '\"' <<
unit_test_log::instance().set_log_threshold_level( log_all_errors );
int i=0;
CHECK_TOOL_USAGE(
BOOST_CHECK_THROW( i++, my_exception ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": exception my_exception is expected\n", 2 ) )
);
unit_test_log::instance().set_log_threshold_level( log_successful_tests );
CHECK_TOOL_USAGE(
BOOST_CHECK_THROW( throw my_exception(), my_exception ),
output.is_equal( CHECK_PATTERN( "info: exception my_exception is caught\n", 2 ) )
);
unit_test_log::instance().set_log_threshold_level( log_all_errors );
}
//____________________________________________________________________________//
void
test_BOOST_CHECK_EXCEPTION()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_CHECK_EXCEPTION" << '\"' <<
unit_test_log::instance().set_log_threshold_level( log_all_errors );
CHECK_TOOL_USAGE(
BOOST_CHECK_EXCEPTION( throw my_exception( 1 ), my_exception, is_critical ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": incorrect exception my_exception is caught\n", 2 ) )
);
unit_test_log::instance().set_log_threshold_level( log_successful_tests );
CHECK_TOOL_USAGE(
BOOST_CHECK_EXCEPTION( throw my_exception( -1 ), my_exception, is_critical ),
output.is_equal( CHECK_PATTERN( "info: incorrect exception my_exception is caught\n", 2 ) )
);
unit_test_log::instance().set_log_threshold_level( log_all_errors );
}
//____________________________________________________________________________//
void
test_BOOST_CHECK_NO_THROW()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_CHECK_NO_THROW" << '\"' <<
int i=0;
CHECK_TOOL_USAGE(
BOOST_CHECK_NO_THROW( i++ ),
output.is_empty()
);
CHECK_TOOL_USAGE(
BOOST_CHECK_NO_THROW( throw my_exception() ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": exception was thrown by throw my_exception()\n", 2 ) )
);
}
//____________________________________________________________________________//
void
test_BOOST_CHECK_EQUAL_COLLECTIONS()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_CHECK_EQUAL_COLLECTIONS" << '\"' <<
unit_test_log::instance().set_log_threshold_level( log_all_errors );
int pattern [] = { 1, 2, 3, 4, 5, 6, 7 };
std::list<int> testlist;
testlist.push_back( 1 );
testlist.push_back( 2 );
testlist.push_back( 4 ); // 3
testlist.push_back( 4 );
testlist.push_back( 5 );
testlist.push_back( 7 ); // 6
testlist.push_back( 7 );
#if !defined(__BORLANDC__)
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL_COLLECTIONS( testlist.begin(), testlist.end(), pattern ),
output.is_equal( CHECK_PATTERN(
"error in " TEST_CASE_NAME ": test {testlist.begin(), testlist.end()} == {pattern, ...} failed in a position 2 [4 != 3]\n"
<< normalize_file_name( __FILE__ ) << "(" << __LINE__ << "): "
<< "error in " TEST_CASE_NAME ": test {testlist.begin(), testlist.end()} == {pattern, ...} failed in a position 5 [7 != 6]\n"
, 6 ) )
);
#else
CHECK_TOOL_USAGE(
BOOST_CHECK_EQUAL_COLLECTIONS( testlist.begin(), testlist.end(), pattern ),
output.is_equal( CHECK_PATTERN(
"error in " TEST_CASE_NAME ": test {testlist.begin(), testlist.end()} == {pattern, ...} failed in a position 2 [4 != 3]\n"
<< normalize_file_name( __FILE__ ) << "(" << (__LINE__-6) << "): "
<< "error in " TEST_CASE_NAME ": test {testlist.begin(), testlist.end()} == {pattern, ...} failed in a position 5 [7 != 6]\n"
, 6 ) )
);
#endif
}
//____________________________________________________________________________//
void
test_BOOST_IS_DEFINED()
{
#define SYMBOL1
#define SYMBOL2 std::cout
#define ONE_ARG( arg ) arg
#define TWO_ARG( arg1, arg2 ) BOOST_JOIN( arg1, arg2 )
BOOST_CHECK( BOOST_IS_DEFINED(SYMBOL1) );
BOOST_CHECK( BOOST_IS_DEFINED(SYMBOL2) );
BOOST_CHECK( !BOOST_IS_DEFINED( SYMBOL3 ) );
BOOST_CHECK( BOOST_IS_DEFINED( ONE_ARG(arg1) ) );
BOOST_CHECK( !BOOST_IS_DEFINED( ONE_ARG1(arg1) ) );
BOOST_CHECK( BOOST_IS_DEFINED( TWO_ARG(arg1,arg2) ) );
BOOST_CHECK( !BOOST_IS_DEFINED( TWO_ARG1(arg1,arg2) ) );
}
//____________________________________________________________________________//
void
test_BOOST_BITWISE_EQUAL()
{
#undef TEST_CASE_NAME
#define TEST_CASE_NAME << '\"' << "test_BOOST_BITWISE_EQUAL" << '\"' <<
CHECK_TOOL_USAGE(
BOOST_BITWISE_EQUAL( 0x16, 0x16 ),
output.is_empty()
);
CHECK_TOOL_USAGE(
BOOST_BITWISE_EQUAL( (char)0x06, (char)0x16 ),
output.is_equal( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test (char)0x06 =.= (char)0x16 in the position 4 failed\n", 2 ) )
);
CHECK_TOOL_USAGE(
BOOST_BITWISE_EQUAL( (char)0x26, (char)0x04 ),
output.is_equal(
std::string( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test (char)0x26 =.= (char)0x04 in the position 1 failed\n", 4 ) )
.append( CHECK_PATTERN( "error in " TEST_CASE_NAME ": test (char)0x26 =.= (char)0x04 in the position 5 failed\n", 4 ) ) )
);
}
//____________________________________________________________________________//
test_suite*
init_unit_test_suite( int /*argc*/, char* /*argv*/[] )
{
test_suite* test = BOOST_TEST_SUITE("Test Tools test");
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK ) );
test->add( BOOST_TEST_CASE( &test_BOOST_REQUIRE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_MESSAGE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_WARN ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECKPOINT ) );
test->add( BOOST_TEST_CASE( &test_BOOST_WARN_MESSAGE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_MESSAGE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_REQUIRE_MESSAGE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_EQUAL ) );
test->add( BOOST_TEST_CASE( &test_BOOST_ERROR ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_THROW ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_NO_THROW ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_EXCEPTION ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_EQUAL_COLLECTIONS ) );
test->add( BOOST_TEST_CASE( &test_BOOST_IS_DEFINED ) );
test->add( BOOST_TEST_CASE( &test_BOOST_CHECK_PREDICATE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_REQUIRE_PREDICATE ) );
test->add( BOOST_TEST_CASE( &test_BOOST_BITWISE_EQUAL ) );
return test;
}
//____________________________________________________________________________//
// ***************************************************************************
// Revision History :
//
// $Log: test_tools_test.cpp,v $
// Revision 1.28 2003/12/23 13:23:35 johnmaddock
// Added patch for gcc2.95.3 (and no new iostreams).
//
// Revision 1.27 2003/12/01 00:42:38 rogeeff
// prerelease cleaning
//
// ***************************************************************************
// EOF
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -