genericopenlibs/cppstdlib/stl/test/unit/includes_test.cpp
changeset 31 ce057bb09d0b
child 34 5fae379060a7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/genericopenlibs/cppstdlib/stl/test/unit/includes_test.cpp	Fri Jun 04 16:20:51 2010 +0100
@@ -0,0 +1,103 @@
+/*
+* 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 <cstring>
+#include <vector>
+#include <algorithm>
+
+#include "cppunit/cppunit_proxy.h"
+
+#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
+using namespace std;
+#endif
+
+//
+// TestCase class
+//
+class IncludesTest : public CPPUNIT_NS::TestCase
+{
+  CPPUNIT_TEST_SUITE(IncludesTest);
+  CPPUNIT_TEST(incl0);
+  CPPUNIT_TEST(incl1);
+  CPPUNIT_TEST(incl2);
+  CPPUNIT_TEST_SUITE_END();
+
+protected:
+  void incl0();
+  void incl1();
+  void incl2();
+
+  static bool compare_strings(const char* s1_, const char* s2_)
+  {
+    return strcmp(s1_, s2_) < 0 ? 1 : 0;
+  }
+};
+
+CPPUNIT_TEST_SUITE_REGISTRATION(IncludesTest);
+
+//
+// tests implementation
+//
+void IncludesTest::incl0()
+{
+  int numbers1[5] = { 1, 2, 3, 4, 5 };
+  //int numbers2[5] = { 1, 2, 4, 8, 16 };
+  int numbers3[2] = { 4, 8 };
+  bool r1=includes(numbers1, numbers1 + 5, numbers3, numbers3 + 2);
+  CPPUNIT_ASSERT(!r1);
+}
+void IncludesTest::incl1()
+{
+  vector<int> v1(10);
+  vector<int> v2(3);
+  int i;
+  for (i = 0; (size_t)i < v1.size(); ++i) {
+    v1[i] = i;
+  }
+
+  bool r1=includes(v1.begin(), v1.end(), v2.begin(), v2.end());
+  CPPUNIT_ASSERT(!r1);
+
+  for (i = 0; (size_t)i < v2.size(); ++i)
+    v2[i] = i + 3;
+
+  bool r2=includes(v1.begin(), v1.end(), v2.begin(), v2.end());
+  CPPUNIT_ASSERT(r2);
+}
+void IncludesTest::incl2()
+{
+  char const* names[] = {  "Todd", "Mike", "Graham", "Jack", "Brett"};
+
+  const unsigned nameSize = sizeof(names)/sizeof(names[0]);
+  vector <char const*> v1(nameSize);
+  for (int i = 0; (size_t)i < v1.size(); ++i) {
+    v1[i] = names[i];
+  }
+  vector <char const*> v2(2);
+
+  v2[0] = "foo";
+  v2[1] = "bar";
+  sort(v1.begin(), v1.end(), compare_strings);
+  sort(v2.begin(), v2.end(), compare_strings);
+
+  bool r1 = includes(v1.begin(), v1.end(), v2.begin(), v2.end(), compare_strings);
+  CPPUNIT_ASSERT(!r1);
+
+  v2[0] = "Brett";
+  v2[1] = "Todd";
+  bool r2 = includes(v1.begin(), v1.end(), v2.begin(), v2.end(), compare_strings);
+  CPPUNIT_ASSERT(r2);
+}