1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
/**
* @file
*
* @brief Unit test for unbounded sequences of object references.
*
* $Id$
*
* @author Carlos O'Ryan
*/
#include "testing_object_reference_traits.hpp"
#include "tao/Object_Reference_Traits_T.h"
#include "testing_allocation_traits.hpp"
#include "testing_range_checking.hpp"
#include "mock_reference.hpp"
#include "tao/Unbounded_Value_Sequence_T.h"
#include "tao/Unbounded_Octet_Sequence_T.h"
#include "tao/Unbounded_Object_Reference_Sequence_T.h"
#include "tao/Unbounded_Basic_String_Sequence_T.h"
#include "tao/Unbounded_BD_String_Sequence_T.h"
#include "tao/Unbounded_Sequence_CDR_T.h"
#include "tao/CDR.h"
#include "test_macros.h"
using namespace TAO_VERSIONED_NAMESPACE_NAME::TAO;
typedef unbounded_object_reference_sequence<mock_reference, mock_reference_var> tested_sequence;
CORBA::Boolean operator<< (TAO_OutputCDR &strm, const tested_sequence &sequence)
{
return TAO::marshal_sequence(strm, sequence);
}
CORBA::Boolean operator>> (TAO_InputCDR &strm, tested_sequence &sequence)
{
return TAO::demarshal_sequence(strm, sequence);
}
struct Tester
{
typedef tested_sequence::value_type value_type;
typedef tested_sequence::const_value_type const_value_type;
typedef tested_sequence::element_traits tested_element_traits;
typedef tested_sequence::allocation_traits tested_allocation_traits;
typedef TAO::details::range_checking<value_type,true> range;
value_type * alloc_and_init_buffer()
{
value_type * buf = tested_sequence::allocbuf(8);
buf[0] = mock_reference::allocate(1);
buf[1] = mock_reference::allocate(4);
buf[2] = mock_reference::allocate(9);
buf[3] = mock_reference::allocate(16);
return buf;
}
int check_values(tested_sequence const & a)
{
CHECK_EQUAL( 1, a[0]->id());
CHECK_EQUAL( 4, a[1]->id());
CHECK_EQUAL( 9, a[2]->id());
CHECK_EQUAL(16, a[3]->id());
return 0;
}
int test_stream()
{
value_type * buffer = alloc_and_init_buffer();
expected_calls s(mock_reference::marshal_calls);
{
tested_sequence a;
a.replace(8, 4, buffer, false);
CHECK_EQUAL(CORBA::ULong(8), a.maximum());
CHECK_EQUAL(CORBA::ULong(4), a.length());
CHECK_EQUAL(buffer, a.get_buffer());
CHECK_EQUAL(false, a.release());
check_values(a);
TAO_OutputCDR stream;
stream << a;
FAIL_RETURN_IF_NOT(s.expect(4), s);
}
tested_sequence::freebuf(buffer);
return 0;
}
};
int ACE_TMAIN(int,ACE_TCHAR*[])
{
int status = 0;
Tester x;
status += x.test_stream ();
return status;
}
|