genericopenlibs/cppstdlib/stl/test/unit/rm_cp_test.cpp
changeset 31 ce057bb09d0b
child 34 5fae379060a7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/genericopenlibs/cppstdlib/stl/test/unit/rm_cp_test.cpp	Fri Jun 04 16:20:51 2010 +0100
@@ -0,0 +1,261 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*
+*/
+#include <vector>
+#include <algorithm>
+
+#include "cppunit/cppunit_proxy.h"
+
+#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
+using namespace std;
+#endif
+
+//
+// TestCase class
+//
+class RmCpTest : public CPPUNIT_NS::TestCase
+{
+  CPPUNIT_TEST_SUITE(RmCpTest);
+  CPPUNIT_TEST(remcopy1);
+  CPPUNIT_TEST(remcpif1);
+  CPPUNIT_TEST(remif1);
+  CPPUNIT_TEST(remove1);
+  CPPUNIT_TEST(repcpif1);
+  CPPUNIT_TEST(replace0);
+  CPPUNIT_TEST(replace1);
+  CPPUNIT_TEST(replcpy1);
+  CPPUNIT_TEST(replif1);
+  CPPUNIT_TEST(revcopy1);
+  CPPUNIT_TEST(reverse1);
+  CPPUNIT_TEST_SUITE_END();
+
+protected:
+  void remcopy1();
+  void remcpif1();
+  void remif1();
+  void remove1();
+  void repcpif1();
+  void replace0();
+  void replace1();
+  void replcpy1();
+  void replif1();
+  void revcopy1();
+  void reverse1();
+
+};
+
+CPPUNIT_TEST_SUITE_REGISTRATION(RmCpTest);
+
+static bool odd(int a_)
+{
+  return (a_ % 2) != 0;
+}
+//
+// tests implementation
+//
+
+void RmCpTest::reverse1()
+{
+  int numbers[6] = { 0, 1, 2, 3, 4, 5 };
+
+  reverse(numbers, numbers + 6);
+  CPPUNIT_ASSERT(numbers[0]==5);
+  CPPUNIT_ASSERT(numbers[1]==4);
+  CPPUNIT_ASSERT(numbers[2]==3);
+  CPPUNIT_ASSERT(numbers[3]==2);
+  CPPUNIT_ASSERT(numbers[4]==1);
+  CPPUNIT_ASSERT(numbers[5]==0);
+}
+
+void RmCpTest::revcopy1()
+{
+  int numbers[6] = { 0, 1, 2, 3, 4, 5 };
+
+  int result[6];
+  reverse_copy((int*)numbers, (int*)numbers + 6, (int*)result);
+  // 5 4 3 2 1 0
+  CPPUNIT_ASSERT(result[0]==5);
+  CPPUNIT_ASSERT(result[1]==4);
+  CPPUNIT_ASSERT(result[2]==3);
+  CPPUNIT_ASSERT(result[3]==2);
+  CPPUNIT_ASSERT(result[4]==1);
+  CPPUNIT_ASSERT(result[5]==0);
+}
+
+void RmCpTest::replif1()
+{
+  vector <int> v1(10);
+  for (int i = 0; (size_t)i < v1.size(); ++i)
+    v1[i] = i % 5;
+
+  replace_if(v1.begin(), v1.end(), odd, 42);
+
+  // 0 42 2 42 4 0 42 2 42 4
+  CPPUNIT_ASSERT(v1[0]==0);
+  CPPUNIT_ASSERT(v1[1]==42);
+  CPPUNIT_ASSERT(v1[2]==2);
+  CPPUNIT_ASSERT(v1[3]==42);
+  CPPUNIT_ASSERT(v1[4]==4);
+  CPPUNIT_ASSERT(v1[5]==0);
+  CPPUNIT_ASSERT(v1[6]==42);
+  CPPUNIT_ASSERT(v1[7]==2);
+  CPPUNIT_ASSERT(v1[8]==42);
+  CPPUNIT_ASSERT(v1[9]==4);
+}
+
+void RmCpTest::replcpy1()
+{
+  int numbers[6] = { 0, 1, 2, 0, 1, 2 };
+  int result[6] = { 0, 0, 0, 0, 0, 0 };
+
+  replace_copy((int*)numbers, (int*)numbers + 6, (int*)result, 2, 42);
+  CPPUNIT_ASSERT(result[0]==0);
+  CPPUNIT_ASSERT(result[1]==1);
+  CPPUNIT_ASSERT(result[2]==42);
+  CPPUNIT_ASSERT(result[3]==0);
+  CPPUNIT_ASSERT(result[4]==1);
+  CPPUNIT_ASSERT(result[5]==42);
+}
+
+void RmCpTest::replace0()
+{
+  int numbers[6] = { 0, 1, 2, 0, 1, 2 };
+
+  replace(numbers, numbers + 6, 2, 42);
+
+  // 0 1 42 0 1 42
+  CPPUNIT_ASSERT(numbers[0]==0);
+  CPPUNIT_ASSERT(numbers[1]==1);
+  CPPUNIT_ASSERT(numbers[2]==42);
+  CPPUNIT_ASSERT(numbers[3]==0);
+  CPPUNIT_ASSERT(numbers[4]==1);
+  CPPUNIT_ASSERT(numbers[5]==42);
+}
+
+void RmCpTest::replace1()
+{
+  vector <int> v1(10);
+  for (int i = 0; (size_t)i < v1.size(); ++i)
+    v1[i] = i % 5;
+  replace(v1.begin(), v1.end(), 2, 42);
+
+  // 0 1 2 3 4 0 1 2 3 4
+  // 0 1 42 3 4 0 1 42 3 4
+  CPPUNIT_ASSERT(v1[0]==0);
+  CPPUNIT_ASSERT(v1[1]==1);
+  CPPUNIT_ASSERT(v1[2]==42);
+  CPPUNIT_ASSERT(v1[3]==3);
+  CPPUNIT_ASSERT(v1[4]==4);
+  CPPUNIT_ASSERT(v1[5]==0);
+  CPPUNIT_ASSERT(v1[6]==1);
+  CPPUNIT_ASSERT(v1[7]==42);
+  CPPUNIT_ASSERT(v1[8]==3);
+  CPPUNIT_ASSERT(v1[9]==4);
+}
+
+void RmCpTest::repcpif1()
+{
+  vector <int> v1(10);
+  for (int i = 0; (size_t)i < v1.size(); ++i)
+    v1[i] = i % 5;
+  vector <int> v2(v1.size());
+
+  // 0 1 2 3 4 0 1 2 3 4
+  // 0 1 2 3 4 0 1 2 3 4
+  // 0 42 2 42 4 0 42 2 42 4
+  replace_copy_if(v1.begin(), v1.end(), v2.begin(), odd, 42);
+  CPPUNIT_ASSERT(v1[0]==0);
+  CPPUNIT_ASSERT(v1[1]==1);
+  CPPUNIT_ASSERT(v1[2]==2);
+  CPPUNIT_ASSERT(v1[3]==3);
+  CPPUNIT_ASSERT(v1[4]==4);
+  CPPUNIT_ASSERT(v1[5]==0);
+  CPPUNIT_ASSERT(v1[6]==1);
+  CPPUNIT_ASSERT(v1[7]==2);
+  CPPUNIT_ASSERT(v1[8]==3);
+  CPPUNIT_ASSERT(v1[9]==4);
+
+  CPPUNIT_ASSERT(v2[0]==0);
+  CPPUNIT_ASSERT(v2[1]==42);
+  CPPUNIT_ASSERT(v2[2]==2);
+  CPPUNIT_ASSERT(v2[3]==42);
+  CPPUNIT_ASSERT(v2[4]==4);
+  CPPUNIT_ASSERT(v2[5]==0);
+  CPPUNIT_ASSERT(v2[6]==42);
+  CPPUNIT_ASSERT(v2[7]==2);
+  CPPUNIT_ASSERT(v2[8]==42);
+  CPPUNIT_ASSERT(v2[9]==4);
+}
+
+void RmCpTest::remove1()
+{
+  int numbers[6] = { 1, 2, 3, 1, 2, 3 };
+  remove((int*)numbers, (int*)numbers + 6, 1);
+
+  // 2 3 2 3 2 3
+  CPPUNIT_ASSERT(numbers[0]==2);
+  CPPUNIT_ASSERT(numbers[1]==3);
+  CPPUNIT_ASSERT(numbers[2]==2);
+  CPPUNIT_ASSERT(numbers[3]==3);
+  CPPUNIT_ASSERT(numbers[4]==2);
+  CPPUNIT_ASSERT(numbers[5]==3);
+}
+
+void RmCpTest::remif1()
+{
+  int numbers[6] = { 0, 0, 1, 1, 2, 2 };
+
+  remove_if((int*)numbers, (int*)numbers + 6, odd);
+
+  // 0 0 2 2 2 2
+  CPPUNIT_ASSERT(numbers[0]==0);
+  CPPUNIT_ASSERT(numbers[1]==0);
+  CPPUNIT_ASSERT(numbers[2]==2);
+  CPPUNIT_ASSERT(numbers[3]==2);
+  CPPUNIT_ASSERT(numbers[4]==2);
+  CPPUNIT_ASSERT(numbers[5]==2);
+}
+
+void RmCpTest::remcopy1()
+{
+  int numbers[6] = { 1, 2, 3, 1, 2, 3 };
+  int result[6] = { 0, 0, 0, 0, 0, 0 };
+
+  remove_copy((int*)numbers, (int*)numbers + 6, (int*)result, 2);
+
+  CPPUNIT_ASSERT(result[0]==1);
+  CPPUNIT_ASSERT(result[1]==3);
+  CPPUNIT_ASSERT(result[2]==1);
+  CPPUNIT_ASSERT(result[3]==3);
+  CPPUNIT_ASSERT(result[4]==0);
+  CPPUNIT_ASSERT(result[5]==0);
+}
+
+void RmCpTest::remcpif1()
+{
+  int numbers[6] = { 1, 2, 3, 1, 2, 3 };
+  int result[6] = { 0, 0, 0, 0, 0, 0 };
+
+  remove_copy_if((int*)numbers, (int*)numbers + 6, (int*)result, odd);
+
+  // 2 2 0 0 0 0
+  CPPUNIT_ASSERT(result[0]==2);
+  CPPUNIT_ASSERT(result[1]==2);
+  CPPUNIT_ASSERT(result[2]==0);
+  CPPUNIT_ASSERT(result[3]==0);
+  CPPUNIT_ASSERT(result[4]==0);
+  CPPUNIT_ASSERT(result[5]==0);
+}