sl@0: /*********************************************************************************** sl@0: test_set.cpp sl@0: sl@0: * Copyright (c) 1997 sl@0: * Mark of the Unicorn, Inc. sl@0: * sl@0: * Permission to use, copy, modify, distribute and sell this software sl@0: * and its documentation for any purpose is hereby granted without fee, sl@0: * provided that the above copyright notice appear in all copies and sl@0: * that both that copyright notice and this permission notice appear sl@0: * in supporting documentation. Mark of the Unicorn makes no sl@0: * representations about the suitability of this software for any sl@0: * purpose. It is provided "as is" without express or implied warranty. sl@0: sl@0: ***********************************************************************************/ sl@0: #include "Tests.h" sl@0: #include "TestClass.h" sl@0: #include "LeakCheck.h" sl@0: #if defined (EH_NEW_HEADERS) sl@0: # include sl@0: #else sl@0: # include sl@0: # include sl@0: #endif sl@0: #include "test_construct.h" sl@0: #include "test_assign_op.h" sl@0: #include "test_push_back.h" sl@0: #include "test_insert.h" sl@0: #include "test_push_front.h" sl@0: #include "ThrowCompare.h" sl@0: sl@0: void test_multiset(); sl@0: sl@0: typedef EH_STD::__multiset__ TestMultiSet; sl@0: sl@0: inline multiset_tag sl@0: container_category(const TestMultiSet&) { sl@0: return multiset_tag(); sl@0: } sl@0: sl@0: void test_multiset() { sl@0: TestMultiSet testMultiSet, testMultiSet2; sl@0: sl@0: const size_t setSize = random_number(random_base); sl@0: sl@0: while (testMultiSet.size() < setSize) { sl@0: TestMultiSet::value_type x; sl@0: testMultiSet.insert( x ); sl@0: testMultiSet2.insert( TestMultiSet::value_type() ); sl@0: } sl@0: sl@0: StrongCheck( testMultiSet, test_insert_value(testMultiSet) ); sl@0: sl@0: size_t insCnt = random_number(random_base); sl@0: TestMultiSet::value_type *insFirst = new TestMultiSet::value_type[1+insCnt]; sl@0: WeakCheck( testMultiSet, insert_range_tester(testMultiSet, insFirst, insFirst+insCnt) ); sl@0: ConstCheck( 0, test_construct_pointer_range(insFirst, insFirst+insCnt) ); sl@0: delete[] insFirst; sl@0: WeakCheck( testMultiSet, insert_range_tester(testMultiSet, testMultiSet2.begin(), testMultiSet2.end() ) ); sl@0: sl@0: ConstCheck( 0, test_default_construct() ); sl@0: ConstCheck( 0, test_construct_iter_range( testMultiSet2 ) ); sl@0: ConstCheck( testMultiSet, test_copy_construct() ); sl@0: sl@0: WeakCheck( testMultiSet, test_assign_op( testMultiSet2 ) ); sl@0: } sl@0: sl@0: typedef EH_STD::__set__ TestSet; sl@0: sl@0: inline set_tag sl@0: container_category(const TestSet&) { sl@0: return set_tag(); sl@0: } sl@0: sl@0: void test_set() { sl@0: TestSet testSet, testSet2; sl@0: sl@0: const size_t setSize = random_number(random_base); sl@0: sl@0: while ( testSet.size() < setSize ) { sl@0: TestSet::value_type x; sl@0: testSet.insert( x ); sl@0: testSet2.insert( TestSet::value_type() ); sl@0: } sl@0: StrongCheck( testSet, test_insert_value(testSet) ); sl@0: sl@0: size_t insCnt = random_number(random_base); sl@0: TestSet::value_type *insFirst = new TestSet::value_type[1+insCnt]; sl@0: sl@0: WeakCheck( testSet, insert_range_tester(testSet, insFirst, insFirst+insCnt) ); sl@0: sl@0: ConstCheck( 0, test_construct_pointer_range(insFirst, insFirst+insCnt) ); sl@0: delete[] insFirst; sl@0: WeakCheck( testSet, insert_range_tester(testSet, testSet2.begin(), testSet2.end() ) ); sl@0: sl@0: ConstCheck( 0, test_default_construct() ); sl@0: ConstCheck( 0, test_construct_iter_range( testSet2 ) ); sl@0: ConstCheck( testSet, test_copy_construct() ); sl@0: WeakCheck( testSet, test_assign_op( testSet2 ) ); sl@0: }