sl@0: /*---------------------------------------------------------------------------------------------- sl@0: * Portions Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. sl@0: *---------------------------------------------------------------------------------------------- sl@0: */ sl@0: // Boris - this file is, um, rather incomplete. Please remove from distribution. sl@0: sl@0: /*********************************************************************************** sl@0: test_string.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 "Prefix.h" sl@0: #if defined( EH_VALARRAY_IMPLEMENTED ) sl@0: #include "Tests.h" sl@0: #include sl@0: #include "TestClass.h" sl@0: #include "LeakCheck.h" 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: sl@0: typedef __valarray__ TestValarray; sl@0: sl@0: inline sequence_container_tag sl@0: container_category(const TestValarray&) sl@0: { sl@0: return sequence_container_tag(); sl@0: } sl@0: sl@0: void test_rope() sl@0: { sl@0: TestValarray testValarray, testValarray2; sl@0: size_t ropeSize = random_number(random_base); sl@0: sl@0: while ( testValarray.size() < ropeSize ) sl@0: { sl@0: TestValarray::value_type x = random_number(random_base) ; // initialize before use sl@0: testValarray.push_back( x ); sl@0: testValarray2.push_back( TestValarray::value_type() ); sl@0: } sl@0: WeakCheck( testValarray, test_insert_one(testValarray) ); sl@0: WeakCheck( testValarray, test_insert_one(testValarray, 0) ); sl@0: WeakCheck( testValarray, test_insert_one(testValarray, testValarray.size()) ); sl@0: sl@0: WeakCheck( testValarray, test_insert_n(testValarray, random_number(random_base) ) ); sl@0: WeakCheck( testValarray, test_insert_n(testValarray, random_number(random_base), 0 ) ); sl@0: WeakCheck( testValarray, test_insert_n(testValarray, random_number(random_base), testValarray.size() ) ); sl@0: sl@0: size_t insCnt = random_number(random_base); sl@0: TestValarray::value_type *insFirst = new TestValarray::value_type[1+insCnt]; sl@0: sl@0: WeakCheck( testValarray, insert_range_tester(testValarray, insFirst, insFirst+insCnt) ); sl@0: WeakCheck( testValarray, insert_range_at_begin_tester(testValarray, insFirst, insFirst+insCnt) ); sl@0: WeakCheck( testValarray, insert_range_at_end_tester(testValarray, insFirst, insFirst+insCnt) ); sl@0: sl@0: ConstCheck( 0, test_construct_pointer_range(insFirst, insFirst+insCnt) ); sl@0: delete[] insFirst; sl@0: sl@0: WeakCheck( testValarray, insert_range_tester(testValarray, testValarray2.begin(), testValarray2.end() ) ); sl@0: sl@0: WeakCheck( testValarray, test_push_front(testValarray) ); sl@0: WeakCheck( testValarray, test_push_back(testValarray) ); sl@0: sl@0: ConstCheck( 0, test_default_construct() ); sl@0: ConstCheck( 0, test_construct_n( random_number(random_base) ) ); sl@0: ConstCheck( 0, test_construct_n_instance( random_number(random_base) ) ); sl@0: ConstCheck( 0, test_construct_iter_range( testValarray2 ) ); sl@0: ConstCheck( testValarray, test_copy_construct() ); sl@0: sl@0: WeakCheck( testValarray, test_assign_op( testValarray2 ) ); sl@0: } sl@0: sl@0: #endif // EH_ROPE_IMPLEMENTED