#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); }