#include //size_t and STLport macros #include "cppunit/cppunit_proxy.h" // // TestCase class // class MoveConstructorTest : public CPPUNIT_NS::TestCase { CPPUNIT_TEST_SUITE(MoveConstructorTest); CPPUNIT_TEST(move_construct_test); CPPUNIT_TEST(deque_test); CPPUNIT_TEST(vector_test); CPPUNIT_TEST(move_traits); #if !defined (STLPORT) || defined (_STLP_NO_MOVE_SEMANTIC) || \ defined (_STLP_DONT_SIMULATE_PARTIAL_SPEC_FOR_TYPE_TRAITS) || \ (defined (__BORLANDC__) && (__BORLANDC__ < 0x564)) CPPUNIT_IGNORE; # endif CPPUNIT_TEST(movable_declaration) CPPUNIT_TEST(movable_declaration_assoc) CPPUNIT_TEST(movable_declaration_hash) #if defined (__BORLANDC__) CPPUNIT_STOP_IGNORE; CPPUNIT_TEST(nb_destructor_calls); #endif CPPUNIT_TEST_SUITE_END(); protected: void move_construct_test(); void deque_test(); void vector_test(); void move_traits(); void movable_declaration(); void movable_declaration_assoc(); void movable_declaration_hash(); void nb_destructor_calls(); /* template void standard_test1(_Container const& ref_cont) { vector<_Container> vec_cont(1, ref_cont); typedef typename _Container::value_type value_type; value_type *pvalue = &(*vec_cont.front().begin()); size_t cur_capacity= vec_cont.capacity(); //force reallocation while (cur_capacity == vec_cont.capacity()) { vec_cont.push_back(ref_cont); } bool b=( (pvalue==(&(*vec_cont.front().begin()))) ); CPPUNIT_ASSERT(b); } */ private: void move_traits_vec(); void move_traits_vec_complete(); void move_traits_deq(); void move_traits_deq_complete(); }; struct MovableStruct { MovableStruct() { ++nb_dft_construct_call; } MovableStruct(MovableStruct const&) { ++nb_cpy_construct_call; } #if defined (STLPORT) && !defined (_STLP_NO_MOVE_SEMANTIC) # if defined (_STLP_USE_NAMESPACES) MovableStruct(std::__move_source) # else MovableStruct(__move_source) # endif { ++nb_mv_construct_call; } #endif ~MovableStruct() { ++nb_destruct_call; } MovableStruct& operator = (const MovableStruct&) { ++nb_assignment_call; return *this; } static void reset() { nb_dft_construct_call = nb_cpy_construct_call = nb_mv_construct_call = 0; nb_assignment_call = 0; nb_destruct_call = 0; } static size_t nb_dft_construct_call; static size_t nb_cpy_construct_call; static size_t nb_mv_construct_call; static size_t nb_assignment_call; static size_t nb_destruct_call; //Dummy data just to control struct sizeof //As node allocator implementation align memory blocks on 2 * sizeof(void*) //we give MovableStruct the same size in order to have expected allocation //and not more void* dummy_data[2]; };