X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e068310a5a5fc97c6bd5149f140fbbea134d296d..63509fb3c424dd69d8f5db35f7ae16950b9a3595:/tests/vectors/vectors.cpp?ds=sidebyside diff --git a/tests/vectors/vectors.cpp b/tests/vectors/vectors.cpp index f93afddf7e..ceeea1661c 100644 --- a/tests/vectors/vectors.cpp +++ b/tests/vectors/vectors.cpp @@ -83,6 +83,8 @@ private: CPPUNIT_TEST( Objects ); CPPUNIT_TEST( NonPODs ); CPPUNIT_TEST( Resize ); + CPPUNIT_TEST( Swap ); + CPPUNIT_TEST( Sort ); CPPUNIT_TEST_SUITE_END(); void PushPopTest(); @@ -92,6 +94,8 @@ private: void Objects(); void NonPODs(); void Resize(); + void Swap(); + void Sort(); DECLARE_NO_COPY_CLASS(VectorsTestCase) }; @@ -99,7 +103,7 @@ private: // register in the unnamed registry so that these tests are run by default CPPUNIT_TEST_SUITE_REGISTRATION( VectorsTestCase ); -// also include in it's own registry so that these tests can be run alone +// also include in its own registry so that these tests can be run alone CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( VectorsTestCase, "VectorsTestCase" ); void VectorsTestCase::PushPopTest() @@ -266,3 +270,48 @@ void VectorsTestCase::Resize() CPPUNIT_ASSERT_EQUAL( 17, v[3].GetValue() ); } +void VectorsTestCase::Swap() +{ + wxVector v1, v2; + v1.push_back(17); + v1.swap(v2); + CPPUNIT_ASSERT( v1.empty() ); + CPPUNIT_ASSERT_EQUAL( 1, v2.size() ); + CPPUNIT_ASSERT_EQUAL( 17, v2[0] ); + + v1.push_back(9); + v2.swap(v1); + CPPUNIT_ASSERT_EQUAL( 1, v1.size() ); + CPPUNIT_ASSERT_EQUAL( 17, v1[0] ); + CPPUNIT_ASSERT_EQUAL( 1, v2.size() ); + CPPUNIT_ASSERT_EQUAL( 9, v2[0] ); + + v2.clear(); + v1.swap(v2); + CPPUNIT_ASSERT( v1.empty() ); +} + + +void VectorsTestCase::Sort() +{ + size_t idx; + wxVector v; + + v.push_back(5); + v.push_back(7); + v.push_back(2); + v.push_back(9); + v.push_back(4); + v.push_back(1); + v.push_back(3); + v.push_back(8); + v.push_back(0); + v.push_back(6); + + wxVectorSort(v); + + for (idx=1; idx