os/ossrv/genericopenlibs/cppstdlib/stl/test/unit/foreach_test.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
#include <vector>
sl@0
     2
#include <algorithm>
sl@0
     3
#include "fadapter.h"
sl@0
     4
sl@0
     5
#include "cppunit/cppunit_proxy.h"
sl@0
     6
sl@0
     7
#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
sl@0
     8
using namespace std;
sl@0
     9
#endif
sl@0
    10
sl@0
    11
//
sl@0
    12
// TestCase class
sl@0
    13
//
sl@0
    14
class ForeachTest : public CPPUNIT_NS::TestCase
sl@0
    15
{
sl@0
    16
  CPPUNIT_TEST_SUITE(ForeachTest);
sl@0
    17
  CPPUNIT_TEST(foreach0);
sl@0
    18
  CPPUNIT_TEST(foreach1);
sl@0
    19
  CPPUNIT_TEST_SUITE_END();
sl@0
    20
sl@0
    21
protected:
sl@0
    22
  void foreach0();
sl@0
    23
  void foreach1();
sl@0
    24
};
sl@0
    25
sl@0
    26
CPPUNIT_TEST_SUITE_REGISTRATION(ForeachTest);
sl@0
    27
sl@0
    28
//
sl@0
    29
// tests implementation
sl@0
    30
//
sl@0
    31
static void increase(int& a_)
sl@0
    32
{
sl@0
    33
  a_ += 1;
sl@0
    34
}
sl@0
    35
void ForeachTest::foreach0()
sl@0
    36
{
sl@0
    37
  int numbers[10] = { 1, 1, 2, 3, 5, 8, 13, 21, 34, 55 };
sl@0
    38
sl@0
    39
  for_each(numbers, numbers + 10, ptr_fun(increase));
sl@0
    40
sl@0
    41
  CPPUNIT_ASSERT(numbers[0]==2);
sl@0
    42
  CPPUNIT_ASSERT(numbers[1]==2);
sl@0
    43
  CPPUNIT_ASSERT(numbers[2]==3);
sl@0
    44
  CPPUNIT_ASSERT(numbers[3]==4);
sl@0
    45
  CPPUNIT_ASSERT(numbers[4]==6);
sl@0
    46
  CPPUNIT_ASSERT(numbers[5]==9);
sl@0
    47
  CPPUNIT_ASSERT(numbers[6]==14);
sl@0
    48
  CPPUNIT_ASSERT(numbers[7]==22);
sl@0
    49
  CPPUNIT_ASSERT(numbers[8]==35);
sl@0
    50
  CPPUNIT_ASSERT(numbers[9]==56);
sl@0
    51
}
sl@0
    52
static void sqr(int& a_)
sl@0
    53
{
sl@0
    54
  a_ = a_ * a_;
sl@0
    55
}
sl@0
    56
void ForeachTest::foreach1()
sl@0
    57
{
sl@0
    58
  vector<int> v1(10);
sl@0
    59
  for (int i = 0; (size_t)i < v1.size(); ++i)
sl@0
    60
    v1[i] = i;
sl@0
    61
  for_each(v1.begin(), v1.end(), ptr_fun(sqr) );
sl@0
    62
sl@0
    63
  CPPUNIT_ASSERT(v1[0]==0);
sl@0
    64
  CPPUNIT_ASSERT(v1[1]==1);
sl@0
    65
  CPPUNIT_ASSERT(v1[2]==4);
sl@0
    66
  CPPUNIT_ASSERT(v1[3]==9);
sl@0
    67
  CPPUNIT_ASSERT(v1[4]==16);
sl@0
    68
  CPPUNIT_ASSERT(v1[5]==25);
sl@0
    69
  CPPUNIT_ASSERT(v1[6]==36);
sl@0
    70
  CPPUNIT_ASSERT(v1[7]==49);
sl@0
    71
  CPPUNIT_ASSERT(v1[8]==64);
sl@0
    72
  CPPUNIT_ASSERT(v1[9]==81);
sl@0
    73
}