VirtualBox

source: vbox/trunk/src/VBox/Runtime/testcase/tstVector.cpp@ 77824

Last change on this file since 77824 was 76553, checked in by vboxsync, 6 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.2 KB
Line 
1/* $Id: tstVector.cpp 76553 2019-01-01 01:45:53Z vboxsync $ */
2/** @file
3 * IPRT Testcase - Vector container structure.
4 */
5
6/*
7 * Copyright (C) 2011-2019 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28/*********************************************************************************************************************************
29* Header Files *
30*********************************************************************************************************************************/
31#include <iprt/test.h>
32#include <iprt/vector.h>
33
34#include <stdlib.h> /* For realloc */
35
36/** Counter of the number of delete calls made so far */
37static unsigned s_cDeleteCalls = 0;
38
39/** Record the argument of the delete function here. */
40static void *s_apvDeleteArg[10];
41
42/** Dummy delete function for vector-of-void pointer elements */
43static void deletePVoid(void **ppv)
44{
45 if (s_cDeleteCalls < RT_ELEMENTS(s_apvDeleteArg))
46 s_apvDeleteArg[s_cDeleteCalls] = *ppv;
47 ++s_cDeleteCalls;
48}
49
50/** Dummy delete by value function for vector-of-void pointer elements */
51static void deletePVoidValue(void *pv)
52{
53 if (s_cDeleteCalls < RT_ELEMENTS(s_apvDeleteArg))
54 s_apvDeleteArg[s_cDeleteCalls] = pv;
55 ++s_cDeleteCalls;
56}
57
58/* Start by instantiating each function once for syntax checking */
59#ifdef __clang__
60# pragma GCC diagnostic ignored "-Wunused-function" /* https://llvm.org/bugs/show_bug.cgi?id=22712 */
61#endif
62RTVEC_DECL_STRUCT(tstInstance, void *)
63RTVEC_DECL_STRUCT(tstInstance2, void *)
64
65RTVEC_DECLFN_DELETE_ADAPTER_ID(tstInstance, void *)
66RTVEC_DECLFN_DELETE_ADAPTER_TO_VALUE(tstInstance, void *)
67
68RTVEC_DECLFN_SIZE(tstInstance, void *)
69RTVEC_DECLFN_RESERVE(tstInstance, void *, rtvecReallocDefTag)
70RTVEC_DECLFN_BEGIN(tstInstance, void *)
71RTVEC_DECLFN_END(tstInstance, void *)
72RTVEC_DECLFN_PUSHBACK(tstInstance, void *)
73RTVEC_DECLFN_POPBACK(tstInstance)
74RTVEC_DECLFN_POPBACK_DELETE(tstInstance2, void *, deletePVoid, tstInstanceDeleteAdapterId)
75RTVEC_DECLFN_CLEAR(tstInstance)
76RTVEC_DECLFN_CLEAR_DELETE(tstInstance2, deletePVoid, tstInstanceDeleteAdapterId)
77RTVEC_DECLFN_DETACH(tstInstance, void *)
78
79RTVEC_DECL(tstSimple, void *)
80
81static void testVectorSimple(void)
82{
83 RTTestISub("Vector structure, no cleanup callback");
84
85 struct tstSimple myVec = RTVEC_INITIALIZER;
86 void **ppvVal;
87
88 RTTESTI_CHECK(tstSimpleSize(&myVec) == 0);
89
90 ppvVal = tstSimplePushBack(&myVec);
91 /* AssertPtrReturnVoid(ppvVal); */
92 RTTESTI_CHECK(ppvVal == tstSimpleBegin(&myVec));
93 RTTESTI_CHECK(ppvVal + 1 == tstSimpleEnd(&myVec));
94 RTTESTI_CHECK(tstSimpleSize(&myVec) == 1);
95 *ppvVal = (void *)1;
96
97 ppvVal = tstSimplePushBack(&myVec);
98 /* AssertPtrReturnVoid(ppvVal); */
99 RTTESTI_CHECK(ppvVal - 1 == tstSimpleBegin(&myVec));
100 RTTESTI_CHECK(ppvVal + 1 == tstSimpleEnd(&myVec));
101 RTTESTI_CHECK(tstSimpleSize(&myVec) == 2);
102 RTTESTI_CHECK(ppvVal[-1] == (void *)1);
103
104 *ppvVal = (void *)3;
105 ppvVal = tstSimplePushBack(&myVec);
106 /* AssertPtrReturnVoid(ppvVal); */
107 RTTESTI_CHECK(ppvVal - 2 == tstSimpleBegin(&myVec));
108 RTTESTI_CHECK(ppvVal + 1 == tstSimpleEnd(&myVec));
109 RTTESTI_CHECK(tstSimpleSize(&myVec) == 3);
110 RTTESTI_CHECK(ppvVal[-2] == (void *)1);
111 RTTESTI_CHECK(ppvVal[-1] == (void *)3);
112
113 tstSimplePopBack(&myVec);
114 RTTESTI_CHECK(tstSimpleBegin(&myVec) + 2 == tstSimpleEnd(&myVec));
115 RTTESTI_CHECK(*tstSimpleBegin(&myVec) == (void *)1);
116 RTTESTI_CHECK(*(tstSimpleEnd(&myVec) - 1) == (void *)3);
117
118 tstSimpleClear(&myVec);
119 RTTESTI_CHECK(tstSimpleBegin(&myVec) == tstSimpleEnd(&myVec));
120 ppvVal = tstSimplePushBack(&myVec);
121 /* AssertPtrReturnVoid(ppvVal); */
122 RTTESTI_CHECK(ppvVal == tstSimpleBegin(&myVec));
123 RTTESTI_CHECK(ppvVal + 1 == tstSimpleEnd(&myVec));
124
125 tstSimpleClear(&myVec);
126 ppvVal = tstSimplePushBack(&myVec);
127 /* AssertPtrReturnVoid(ppvVal); */
128 *ppvVal = (void *)1;
129 ppvVal = tstSimplePushBack(&myVec);
130 /* AssertPtrReturnVoid(ppvVal); */
131 *ppvVal = (void *)3;
132 ppvVal = tstSimplePushBack(&myVec);
133 /* AssertPtrReturnVoid(ppvVal); */
134 *ppvVal = (void *)2;
135 ppvVal = tstSimpleDetach(&myVec);
136 RTTESTI_CHECK(tstSimpleBegin(&myVec) == NULL);
137 RTTESTI_CHECK(tstSimpleSize(&myVec) == 0);
138 RTTESTI_CHECK(ppvVal[0] == (void *)1);
139 RTTESTI_CHECK(ppvVal[1] == (void *)3);
140 RTTESTI_CHECK(ppvVal[2] == (void *)2);
141}
142
143RTVEC_DECL_DELETE(tstDelete, void *, deletePVoid)
144
145static void testVectorDelete(void)
146{
147 RTTestISub("Vector structure with cleanup by pointer callback");
148
149 struct tstDelete myVec = RTVEC_INITIALIZER;
150 void **ppvVal;
151
152 ppvVal = tstDeletePushBack(&myVec);
153 /* AssertPtrReturnVoid(ppvVal); */
154 *ppvVal = (void *)1;
155 ppvVal = tstDeletePushBack(&myVec);
156 /* AssertPtrReturnVoid(ppvVal); */
157 *ppvVal = (void *)3;
158 ppvVal = tstDeletePushBack(&myVec);
159 /* AssertPtrReturnVoid(ppvVal); */
160 *ppvVal = (void *)2;
161
162 s_cDeleteCalls = 0;
163 tstDeletePopBack(&myVec);
164 RTTESTI_CHECK(s_cDeleteCalls == 1);
165 RTTESTI_CHECK(s_apvDeleteArg[0] == (void *)2);
166 RTTESTI_CHECK(tstDeleteBegin(&myVec) + 2 == tstDeleteEnd(&myVec));
167 RTTESTI_CHECK(*tstDeleteBegin(&myVec) == (void *)1);
168 RTTESTI_CHECK(*(tstDeleteEnd(&myVec) - 1) == (void *)3);
169
170 s_cDeleteCalls = 0;
171 tstDeleteClear(&myVec);
172 RTTESTI_CHECK(s_cDeleteCalls == 2);
173 RTTESTI_CHECK(s_apvDeleteArg[0] == (void *)1);
174 RTTESTI_CHECK(s_apvDeleteArg[1] == (void *)3);
175 RTTESTI_CHECK(tstDeleteBegin(&myVec) == tstDeleteEnd(&myVec));
176 ppvVal = tstDeletePushBack(&myVec);
177 /* AssertPtrReturnVoid(ppvVal); */
178 RTTESTI_CHECK(ppvVal == tstDeleteBegin(&myVec));
179 RTTESTI_CHECK(ppvVal + 1 == tstDeleteEnd(&myVec));
180}
181
182RTVEC_DECL_DELETE_BY_VALUE(tstDeleteValue, void *, deletePVoidValue)
183
184static void testVectorDeleteValue(void)
185{
186 RTTestISub("Vector structure with cleanup by value callback");
187
188 struct tstDeleteValue myVec = RTVEC_INITIALIZER;
189 void **ppvVal;
190
191 ppvVal = tstDeleteValuePushBack(&myVec);
192 /* AssertPtrReturnVoid(ppvVal); */
193 *ppvVal = (void *)1;
194 ppvVal = tstDeleteValuePushBack(&myVec);
195 /* AssertPtrReturnVoid(ppvVal); */
196 *ppvVal = (void *)3;
197 ppvVal = tstDeleteValuePushBack(&myVec);
198 /* AssertPtrReturnVoid(ppvVal); */
199 *ppvVal = (void *)2;
200
201 s_cDeleteCalls = 0;
202 tstDeleteValuePopBack(&myVec);
203 RTTESTI_CHECK(s_cDeleteCalls == 1);
204 RTTESTI_CHECK(s_apvDeleteArg[0] == (void *)2);
205 RTTESTI_CHECK( tstDeleteValueBegin(&myVec) + 2
206 == tstDeleteValueEnd(&myVec));
207 RTTESTI_CHECK(*tstDeleteValueBegin(&myVec) == (void *)1);
208 RTTESTI_CHECK(*(tstDeleteValueEnd(&myVec) - 1) == (void *)3);
209
210 s_cDeleteCalls = 0;
211 tstDeleteValueClear(&myVec);
212 RTTESTI_CHECK(s_cDeleteCalls == 2);
213 RTTESTI_CHECK(s_apvDeleteArg[0] == (void *)1);
214 RTTESTI_CHECK(s_apvDeleteArg[1] == (void *)3);
215 RTTESTI_CHECK(tstDeleteValueBegin(&myVec) == tstDeleteValueEnd(&myVec));
216 ppvVal = tstDeleteValuePushBack(&myVec);
217 /* AssertPtrReturnVoid(ppvVal); */
218 RTTESTI_CHECK(ppvVal == tstDeleteValueBegin(&myVec));
219 RTTESTI_CHECK(ppvVal + 1 == tstDeleteValueEnd(&myVec));
220}
221
222
223
224int main()
225{
226 RTTEST hTest;
227 RTEXITCODE rcExit = RTTestInitAndCreate("tstVector", &hTest);
228 if (rcExit != RTEXITCODE_SUCCESS)
229 return rcExit;
230
231 testVectorSimple();
232 testVectorDelete();
233 testVectorDeleteValue();
234
235 return RTTestSummaryAndDestroy(hTest);
236}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette