diff options
Diffstat (limited to 'src/boost/libs/assign/test/std.cpp')
-rw-r--r-- | src/boost/libs/assign/test/std.cpp | 231 |
1 files changed, 231 insertions, 0 deletions
diff --git a/src/boost/libs/assign/test/std.cpp b/src/boost/libs/assign/test/std.cpp new file mode 100644 index 00000000..bb2d8fbe --- /dev/null +++ b/src/boost/libs/assign/test/std.cpp @@ -0,0 +1,231 @@ +// Boost.Assign library +// +// Copyright Thorsten Ottosen 2003-2004. Use, modification and +// distribution is subject to the Boost Software License, Version +// 1.0. (See accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt) +// +// For more information, see http://www.boost.org/libs/assign/ +// + + +#include <boost/detail/workaround.hpp> + +#if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) +# pragma warn -8091 // suppress warning in Boost.Test +# pragma warn -8057 // unused argument argc/argv in Boost.Test +#endif + +#include <boost/assign/std.hpp> +#include <boost/test/test_tools.hpp> +#include <utility> +#include <string> + +using std::deque; +using std::list; +using std::vector; +using std::set; +using std::multiset; +using std::map; +using std::multimap; +using std::stack; +using std::queue; +using std::priority_queue; +using std::string; +using std::pair; +using std::make_pair; +using namespace boost::assign; + +template< typename K, typename V > +inline pair<K,V> P( K k, V v ) +{ + return make_pair( k, v ); +} + +struct three +{ + three( int, int, int ) { } + three( const string&, const string&, const string& ) { } +}; + +struct four +{ + four( int, int, int, int ) { } + four( const string&, const string&, const string&, const string& ) { } +}; + +struct five +{ + five( int, int, int, int, int ) { } + five( const string&, const string&, const string&, + const string&, const string& ) { } +}; + + + +template< class C > +void test_int_sequence() +{ + C c; + + BOOST_CHECK_EQUAL( c.size(), 0u ); + c +=1,2,3,4,5,6,7,8,9,10; + BOOST_CHECK_EQUAL( c.size(), 10u ); +} + + + +template< class C > +void test_string_sequence() +{ + C c; + + BOOST_CHECK_EQUAL( c.size(), 0u ); + c += "1","2","3","4","5","6","7","8","9","10"; + BOOST_CHECK_EQUAL( c.size(), 10u ); +} + + + +typedef pair<string,int> two_tuple; + +template< class C > +void test_tuple_sequence() +{ + C c; + + BOOST_CHECK_EQUAL( c.size(), 0u ); + c += P("1",1), P("2",2), P("3",3), P("4",4), P("5",5), P("6",6), + P("7",7), P("8",8), P("9",9), P("10",10); + BOOST_CHECK_EQUAL( c.size(), 10u ); +} + + + +template< class M > +void test_map() +{ + M m; + m += P( "january", 31 ), P( "february", 28 ), + P( "march", 31 ), P( "april", 30 ), + P( "may", 31 ), P( "june", 30 ), + P( "july", 31 ), P( "august", 31 ), + P( "september", 30 ), P( "october", 31 ), + P( "november", 30 ), P( "december", 31 ); + BOOST_CHECK_EQUAL( m.size(), 12u ); + m.clear(); + insert( m ) + ( "january", 31 )( "february", 28 ) + ( "march", 31 )( "april", 30 ) + ( "may", 31 )( "june", 30 ) + ( "july", 31 )( "august", 31 ) + ( "september", 30 )( "october", 31 ) + ( "november", 30 )( "december", 31 ); + BOOST_CHECK_EQUAL( m.size(), 12u ); +} + + + +void test_tuple() +{ + vector<three> v_three; + vector<four> v_four; + vector<five> v_five; + + push_back( v_three ) (1,2,3) ("1","2","3"); + push_back( v_four ) (1,2,3,4) ("1","2","3","4"); + push_back( v_five ) (1,2,3,4,5) ("1","2","3","4","5"); + BOOST_CHECK_EQUAL( v_three.size(), 2u ); + BOOST_CHECK_EQUAL( v_four.size(), 2u ); + BOOST_CHECK_EQUAL( v_five.size(), 2u ); + +} + + + +void check_std() +{ + test_int_sequence< deque<int> >(); + test_int_sequence< list<int> >(); + test_int_sequence< vector<int> >(); + test_int_sequence< set<int> >(); + test_int_sequence< multiset<int> >(); + test_int_sequence< stack<int> >(); + test_int_sequence< queue<int> >(); + test_int_sequence< priority_queue<int> >(); + + test_string_sequence< deque<string> >(); + test_string_sequence< list<string> >(); + test_string_sequence< vector<string> >(); + test_string_sequence< set<string> >(); + test_string_sequence< multiset<string> >(); + test_string_sequence< stack<string> >(); + test_string_sequence< queue<string> >(); + test_string_sequence< priority_queue<string> >(); + + test_tuple_sequence< deque<two_tuple> >(); + test_tuple_sequence< list<two_tuple> >(); + test_tuple_sequence< vector<two_tuple> >(); + test_tuple_sequence< set<two_tuple> >(); + test_tuple_sequence< multiset<two_tuple> >(); + test_tuple_sequence< stack<two_tuple> >(); + test_tuple_sequence< queue<two_tuple> >(); + test_tuple_sequence< priority_queue<two_tuple> >(); + test_tuple(); + + deque<int> di; + push_back( di )( 1 ); + push_front( di )( 2 ); + BOOST_CHECK_EQUAL( di[0], 2 ); + BOOST_CHECK_EQUAL( di[1], 1 ); + + list<int> li; + push_back( li )( 2 ); + push_front( li )( 1 ); + BOOST_CHECK_EQUAL( li.front(), 1 ); + BOOST_CHECK_EQUAL( li.back(), 2 ); + + vector<int> vi; + push_back( vi ) = 2,3; + BOOST_CHECK_EQUAL( vi[0], 2 ); + BOOST_CHECK_EQUAL( vi[1], 3 ); + + set<int> si; + insert( si )( 4 ); + BOOST_CHECK_EQUAL( *si.find( 4 ), 4 ); + + multiset<int> msi; + insert( msi )( 5 ); + BOOST_CHECK_EQUAL( *msi.find( 5 ), 5 ); + + stack<int> sti; + push( sti )( 6 ); + BOOST_CHECK_EQUAL( sti.top(), 6 ); + + queue<int> qi; + push( qi )( 7 ); + BOOST_CHECK_EQUAL( qi.back(), 7 ); + + priority_queue<int> pqi; + push( pqi )( 8 ); + BOOST_CHECK_EQUAL( pqi.top(), 8 ); + + test_map< map<string,int> >(); + test_map< multimap<string,int> >(); + +} + + + +#include <boost/test/unit_test.hpp> +using boost::unit_test::test_suite; + +test_suite* init_unit_test_suite( int argc, char* argv[] ) +{ + test_suite* test = BOOST_TEST_SUITE( "List Test Suite" ); + + test->add( BOOST_TEST_CASE( &check_std ) ); + + return test; +} + |