sl@0
|
1 |
#include <new>
|
sl@0
|
2 |
#include <vector>
|
sl@0
|
3 |
|
sl@0
|
4 |
#include "cppunit/cppunit_proxy.h"
|
sl@0
|
5 |
|
sl@0
|
6 |
#if defined (_STLP_USE_NAMESPACES)
|
sl@0
|
7 |
using namespace std;
|
sl@0
|
8 |
#endif
|
sl@0
|
9 |
|
sl@0
|
10 |
//
|
sl@0
|
11 |
// TestCase class
|
sl@0
|
12 |
//
|
sl@0
|
13 |
class ConfigTest : public CPPUNIT_NS::TestCase
|
sl@0
|
14 |
{
|
sl@0
|
15 |
CPPUNIT_TEST_SUITE(ConfigTest);
|
sl@0
|
16 |
#if !defined (STLPORT)
|
sl@0
|
17 |
CPPUNIT_IGNORE;
|
sl@0
|
18 |
#endif
|
sl@0
|
19 |
CPPUNIT_TEST(placement_new_bug);
|
sl@0
|
20 |
CPPUNIT_TEST(endianess);
|
sl@0
|
21 |
CPPUNIT_TEST(template_function_partial_ordering);
|
sl@0
|
22 |
CPPUNIT_TEST_SUITE_END();
|
sl@0
|
23 |
|
sl@0
|
24 |
protected:
|
sl@0
|
25 |
void placement_new_bug();
|
sl@0
|
26 |
void endianess();
|
sl@0
|
27 |
void template_function_partial_ordering();
|
sl@0
|
28 |
};
|
sl@0
|
29 |
|
sl@0
|
30 |
CPPUNIT_TEST_SUITE_REGISTRATION(ConfigTest);
|
sl@0
|
31 |
|
sl@0
|
32 |
void ConfigTest::placement_new_bug()
|
sl@0
|
33 |
{
|
sl@0
|
34 |
#if defined (STLPORT)
|
sl@0
|
35 |
int int_val = 1;
|
sl@0
|
36 |
int *pint;
|
sl@0
|
37 |
pint = new(&int_val) int();
|
sl@0
|
38 |
CPPUNIT_ASSERT( pint == &int_val );
|
sl@0
|
39 |
# if defined (_STLP_DEF_CONST_PLCT_NEW_BUG)
|
sl@0
|
40 |
CPPUNIT_ASSERT( int_val != 0 );
|
sl@0
|
41 |
# else
|
sl@0
|
42 |
CPPUNIT_ASSERT( int_val == 0 );
|
sl@0
|
43 |
# endif
|
sl@0
|
44 |
#endif
|
sl@0
|
45 |
}
|
sl@0
|
46 |
|
sl@0
|
47 |
void ConfigTest::endianess()
|
sl@0
|
48 |
{
|
sl@0
|
49 |
#if defined (STLPORT)
|
sl@0
|
50 |
int val = 0x01020304;
|
sl@0
|
51 |
char *ptr = (char*)(&val);
|
sl@0
|
52 |
# if defined (_STLP_BIG_ENDIAN)
|
sl@0
|
53 |
//This test only work if sizeof(int) == 4, this is a known limitation
|
sl@0
|
54 |
//that will be handle the day we find a compiler for which it is false.
|
sl@0
|
55 |
CPPUNIT_ASSERT( *ptr == 0x01 ||
|
sl@0
|
56 |
sizeof(int) > 4 && *ptr == 0x00 );
|
sl@0
|
57 |
# elif defined (_STLP_LITTLE_ENDIAN)
|
sl@0
|
58 |
CPPUNIT_ASSERT( *ptr == 0x04 );
|
sl@0
|
59 |
# endif
|
sl@0
|
60 |
#endif
|
sl@0
|
61 |
}
|
sl@0
|
62 |
|
sl@0
|
63 |
void ConfigTest::template_function_partial_ordering()
|
sl@0
|
64 |
{
|
sl@0
|
65 |
#if defined (STLPORT)
|
sl@0
|
66 |
vector<int> vect1(10, 0);
|
sl@0
|
67 |
int* pvect1Front = &vect1.front();
|
sl@0
|
68 |
vector<int> vect2(10, 0);
|
sl@0
|
69 |
int* pvect2Front = &vect2.front();
|
sl@0
|
70 |
|
sl@0
|
71 |
swap(vect1, vect2);
|
sl@0
|
72 |
|
sl@0
|
73 |
# if defined (_STLP_FUNCTION_TMPL_PARTIAL_ORDER) || defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND)
|
sl@0
|
74 |
CPPUNIT_ASSERT( pvect1Front == &vect2.front() );
|
sl@0
|
75 |
CPPUNIT_ASSERT( pvect2Front == &vect1.front() );
|
sl@0
|
76 |
# else
|
sl@0
|
77 |
CPPUNIT_ASSERT( pvect1Front != &vect2.front() );
|
sl@0
|
78 |
CPPUNIT_ASSERT( pvect2Front != &vect1.front() );
|
sl@0
|
79 |
# endif
|
sl@0
|
80 |
#endif
|
sl@0
|
81 |
}
|