Update Boost.Array tests to use newer Boost.Test features

[SVN r82822]
This commit is contained in:
Marshall Clow
2013-02-11 17:16:55 +00:00
parent 97a26a1599
commit 117584a2ce
7 changed files with 40 additions and 64 deletions

View File

@ -4,16 +4,21 @@
import testing ; import testing ;
alias unit_test_framework
: # sources
/boost//unit_test_framework
;
test-suite array : test-suite array :
[ run array0.cpp ] [ run array0.cpp unit_test_framework : : : : array0 ]
[ run array1.cpp ] [ run array1.cpp ]
[ run array2.cpp ] [ run array2.cpp ]
[ run array3.cpp ] [ run array3.cpp ]
[ run array4.cpp ] [ run array4.cpp ]
[ run array5.cpp ] [ run array5.cpp ]
[ run array6.cpp ] [ run array6.cpp unit_test_framework : : : : array6 ]
[ run array7.cpp ] [ run array7.cpp unit_test_framework : : : : array7 ]
[ compile-fail array_getfail1.cpp ] [ compile-fail array_getfail1.cpp ]
[ compile-fail array_getfail2.cpp ] [ compile-fail array_getfail2.cpp ]
[ run array_hash.cpp ] [ run array_hash.cpp unit_test_framework : : : : array_hash ]
; ;

View File

@ -9,18 +9,15 @@
#include <iostream> #include <iostream>
#include <boost/array.hpp> #include <boost/array.hpp>
namespace { #define BOOST_TEST_MAIN
unsigned int failed_tests = 0; #include <boost/test/unit_test.hpp>
void fail_test( const char * reason ) { namespace {
++failed_tests;
std::cerr << "Test failure " << failed_tests << ": " << reason << std::endl;
}
template< class T > template< class T >
void BadValue( const T & ) void BadValue( const T & )
{ {
fail_test( "Unexpected value" ); BOOST_CHECK ( false );
} }
template< class T > template< class T >
@ -36,46 +33,24 @@ void RunTests()
// front/back and operator[] must compile, but calling them is undefined // front/back and operator[] must compile, but calling them is undefined
// Likewise, all tests below should evaluate to false, avoiding undefined behaviour // Likewise, all tests below should evaluate to false, avoiding undefined behaviour
if( !test_case.empty() ) { BOOST_CHECK ( test_case.empty());
BadValue( test_case.front() ); BOOST_CHECK ( const_test_case.empty());
}
if( !const_test_case.empty() ) { BOOST_CHECK ( test_case.size() == 0 );
BadValue( const_test_case.back() ); BOOST_CHECK ( const_test_case.size() == 0 );
}
if( test_case.size() > 0 ) {
BadValue( test_case[ 0 ] );
}
if( const_test_case.max_size() > 0 ) {
BadValue( const_test_case[ 0 ] );
}
// Assert requirements of TR1 6.2.2.4 // Assert requirements of TR1 6.2.2.4
if( test_case.begin() != test_case.end() ) { BOOST_CHECK ( test_case.begin() == test_case.end());
fail_test( "Not an empty range" ); BOOST_CHECK ( test_case.cbegin() == test_case.cend());
} BOOST_CHECK ( const_test_case.begin() == const_test_case.end());
if( test_case.cbegin() != test_case.cend() ) { BOOST_CHECK ( const_test_case.cbegin() == const_test_case.cend());
fail_test( "Not an empty range" );
}
if( const_test_case.begin() != const_test_case.end() ) {
fail_test( "Not an empty range" );
}
if( const_test_case.cbegin() != const_test_case.cend() ) {
fail_test( "Not an empty range" );
}
if( test_case.begin() == const_test_case.begin() ) {
fail_test( "iterators for different containers are not distinct" );
}
BOOST_CHECK ( test_case.begin() != const_test_case.begin() );
if( test_case.data() == const_test_case.data() ) { if( test_case.data() == const_test_case.data() ) {
// Value of data is unspecified in TR1, so no requirement this test pass or fail // Value of data is unspecified in TR1, so no requirement this test pass or fail
// However, it must compile! // However, it must compile!
} }
// Check can safely use all iterator types with std algorithms // Check can safely use all iterator types with std algorithms
std::for_each( test_case.begin(), test_case.end(), BadValue< T > ); std::for_each( test_case.begin(), test_case.end(), BadValue< T > );
std::for_each( test_case.rbegin(), test_case.rend(), BadValue< T > ); std::for_each( test_case.rbegin(), test_case.rend(), BadValue< T > );
@ -87,12 +62,12 @@ void RunTests()
// Check swap is well formed // Check swap is well formed
std::swap( test_case, test_case ); std::swap( test_case, test_case );
// Check assigment operator and overloads are well formed // Check assignment operator and overloads are well formed
test_case = const_test_case; test_case = const_test_case;
// Confirm at() throws the std lib defined exception // Confirm at() throws the std lib defined exception
try { try {
BadValue( test_case.at( 0 ) ); BadValue( test_case.at( 0 ));
} catch ( const std::out_of_range & ) { } catch ( const std::out_of_range & ) {
} }
@ -104,12 +79,11 @@ void RunTests()
} }
int main() BOOST_AUTO_TEST_CASE( test_main )
{ {
RunTests< bool >(); RunTests< bool >();
RunTests< void * >(); RunTests< void * >();
RunTests< long double >(); RunTests< long double >();
RunTests< std::string >(); RunTests< std::string >();
return failed_tests;
} }

View File

@ -10,8 +10,8 @@
#include <boost/array.hpp> #include <boost/array.hpp>
#include <algorithm> #include <algorithm>
#include <boost/test/included/test_exec_monitor.hpp> #define BOOST_TEST_MAIN
#include <boost/test/unit_test.hpp>
namespace { namespace {
template< class T > template< class T >
@ -30,12 +30,11 @@ namespace {
} }
} }
int test_main( int , char* [] ) BOOST_AUTO_TEST_CASE( test_main )
{ {
RunTests< bool >(); RunTests< bool >();
RunTests< void * >(); RunTests< void * >();
RunTests< long double >(); RunTests< long double >();
RunTests< std::string >(); RunTests< std::string >();
return 0;
} }

View File

@ -13,7 +13,8 @@
#include <array> #include <array>
#endif #endif
#include <boost/test/included/test_exec_monitor.hpp> #define BOOST_TEST_MAIN
#include <boost/test/unit_test.hpp>
namespace { namespace {
@ -49,7 +50,7 @@ namespace {
} }
int test_main( int , char* [] ) BOOST_AUTO_TEST_CASE( test_main )
{ {
RunBoostTests< bool >(); RunBoostTests< bool >();
RunBoostTests< void * >(); RunBoostTests< void * >();
@ -62,6 +63,5 @@ int test_main( int , char* [] )
RunStdTests< long double >(); RunStdTests< long double >();
RunStdTests< std::string >(); RunStdTests< std::string >();
#endif #endif
return 0;
} }

View File

@ -16,7 +16,8 @@
#include <array> #include <array>
#endif #endif
#include <boost/test/included/test_exec_monitor.hpp> #define BOOST_TEST_MAIN
#include <boost/test/unit_test.hpp>
namespace { namespace {
@ -35,9 +36,8 @@ namespace {
} }
int test_main( int , char* [] ) BOOST_AUTO_TEST_CASE( test_main )
{ {
#ifndef BOOST_NO_CXX11_HDR_ARRAY #ifndef BOOST_NO_CXX11_HDR_ARRAY
RunStdTests< bool >(); RunStdTests< bool >();
RunStdTests< void * >(); RunStdTests< void * >();
@ -46,6 +46,5 @@ int test_main( int , char* [] )
#else #else
BOOST_STATIC_ASSERT ( false ); // fail on C++03 systems. BOOST_STATIC_ASSERT ( false ); // fail on C++03 systems.
#endif #endif
return 0;
} }

View File

@ -13,7 +13,8 @@
#include <array> #include <array>
#endif #endif
#include <boost/test/included/test_exec_monitor.hpp> #define BOOST_TEST_MAIN
#include <boost/test/unit_test.hpp>
namespace { namespace {
@ -46,7 +47,7 @@ namespace {
} }
int test_main( int , char* [] ) BOOST_AUTO_TEST_CASE( test_main )
{ {
RunBoostTests< bool >(); RunBoostTests< bool >();
RunBoostTests< void * >(); RunBoostTests< void * >();
@ -59,6 +60,5 @@ int test_main( int , char* [] )
RunStdTests< long double >(); RunStdTests< long double >();
RunStdTests< std::string >(); RunStdTests< std::string >();
#endif #endif
return 0;
} }

View File

@ -11,7 +11,8 @@
#include <algorithm> #include <algorithm>
#include <boost/functional/hash.hpp> #include <boost/functional/hash.hpp>
#include <boost/test/included/test_exec_monitor.hpp> #define BOOST_TEST_MAIN
#include <boost/test/unit_test.hpp>
namespace { namespace {
@ -33,12 +34,10 @@ namespace {
} }
int test_main( int , char* [] ) BOOST_AUTO_TEST_CASE( test_main )
{ {
RunTests< int >(); RunTests< int >();
RunTests< long >(); RunTests< long >();
RunTests< long double >(); RunTests< long double >();
return 0;
} }