1*35238bceSAndroid Build Coastguard Worker /*-------------------------------------------------------------------------
2*35238bceSAndroid Build Coastguard Worker * drawElements Memory Pool Library
3*35238bceSAndroid Build Coastguard Worker * --------------------------------
4*35238bceSAndroid Build Coastguard Worker *
5*35238bceSAndroid Build Coastguard Worker * Copyright 2014 The Android Open Source Project
6*35238bceSAndroid Build Coastguard Worker *
7*35238bceSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
8*35238bceSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
9*35238bceSAndroid Build Coastguard Worker * You may obtain a copy of the License at
10*35238bceSAndroid Build Coastguard Worker *
11*35238bceSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
12*35238bceSAndroid Build Coastguard Worker *
13*35238bceSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
14*35238bceSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
15*35238bceSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16*35238bceSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
17*35238bceSAndroid Build Coastguard Worker * limitations under the License.
18*35238bceSAndroid Build Coastguard Worker *
19*35238bceSAndroid Build Coastguard Worker *//*!
20*35238bceSAndroid Build Coastguard Worker * \file
21*35238bceSAndroid Build Coastguard Worker * \brief Memory pool multiset class.
22*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/
23*35238bceSAndroid Build Coastguard Worker
24*35238bceSAndroid Build Coastguard Worker #include "dePoolMultiSet.h"
25*35238bceSAndroid Build Coastguard Worker
26*35238bceSAndroid Build Coastguard Worker DE_DECLARE_POOL_MULTISET(deTestMultiSet, int16_t);
27*35238bceSAndroid Build Coastguard Worker DE_IMPLEMENT_POOL_MULTISET(deTestMultiSet, int16_t, deInt16Hash, deInt16Equal);
28*35238bceSAndroid Build Coastguard Worker
dePoolMultiSet_selfTest(void)29*35238bceSAndroid Build Coastguard Worker void dePoolMultiSet_selfTest(void)
30*35238bceSAndroid Build Coastguard Worker {
31*35238bceSAndroid Build Coastguard Worker deMemPool *pool = deMemPool_createRoot(DE_NULL, 0);
32*35238bceSAndroid Build Coastguard Worker deTestMultiSet *set = deTestMultiSet_create(pool);
33*35238bceSAndroid Build Coastguard Worker int i;
34*35238bceSAndroid Build Coastguard Worker
35*35238bceSAndroid Build Coastguard Worker /* Test exists() on empty set. */
36*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 0);
37*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 15000; i++)
38*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(!deTestMultiSet_exists(set, (int16_t)i));
39*35238bceSAndroid Build Coastguard Worker
40*35238bceSAndroid Build Coastguard Worker /* Test insert(). */
41*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 5000; i++)
42*35238bceSAndroid Build Coastguard Worker deTestMultiSet_insert(set, (int16_t)i);
43*35238bceSAndroid Build Coastguard Worker
44*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 5000);
45*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 25000; i++)
46*35238bceSAndroid Build Coastguard Worker {
47*35238bceSAndroid Build Coastguard Worker bool inserted = deInBounds32(i, 0, 5000);
48*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
49*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == inserted);
50*35238bceSAndroid Build Coastguard Worker }
51*35238bceSAndroid Build Coastguard Worker
52*35238bceSAndroid Build Coastguard Worker /* Test delete(). */
53*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 1000; i++)
54*35238bceSAndroid Build Coastguard Worker deTestMultiSet_delete(set, (int16_t)i);
55*35238bceSAndroid Build Coastguard Worker
56*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 4000);
57*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 25000; i++)
58*35238bceSAndroid Build Coastguard Worker {
59*35238bceSAndroid Build Coastguard Worker bool inserted = deInBounds32(i, 1000, 5000);
60*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
61*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == inserted);
62*35238bceSAndroid Build Coastguard Worker }
63*35238bceSAndroid Build Coastguard Worker
64*35238bceSAndroid Build Coastguard Worker /* Test insert() after delete(). */
65*35238bceSAndroid Build Coastguard Worker for (i = 10000; i < 12000; i++)
66*35238bceSAndroid Build Coastguard Worker deTestMultiSet_insert(set, (int16_t)i);
67*35238bceSAndroid Build Coastguard Worker
68*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 6000);
69*35238bceSAndroid Build Coastguard Worker
70*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 25000; i++)
71*35238bceSAndroid Build Coastguard Worker {
72*35238bceSAndroid Build Coastguard Worker bool inserted = (deInBounds32(i, 1000, 5000) || deInBounds32(i, 10000, 12000));
73*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
74*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == inserted);
75*35238bceSAndroid Build Coastguard Worker }
76*35238bceSAndroid Build Coastguard Worker
77*35238bceSAndroid Build Coastguard Worker /* Test reset. */
78*35238bceSAndroid Build Coastguard Worker deTestMultiSet_reset(set);
79*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 0);
80*35238bceSAndroid Build Coastguard Worker
81*35238bceSAndroid Build Coastguard Worker /* Test insertion multiple times. */
82*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 1000; i++)
83*35238bceSAndroid Build Coastguard Worker deTestMultiSet_insert(set, (int16_t)i);
84*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 500; i++)
85*35238bceSAndroid Build Coastguard Worker deTestMultiSet_insert(set, (int16_t)i);
86*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 250; i++)
87*35238bceSAndroid Build Coastguard Worker deTestMultiSet_insert(set, (int16_t)i);
88*35238bceSAndroid Build Coastguard Worker
89*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 1000 + 500 + 250);
90*35238bceSAndroid Build Coastguard Worker
91*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 2000; i++)
92*35238bceSAndroid Build Coastguard Worker {
93*35238bceSAndroid Build Coastguard Worker int count = 0;
94*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
95*35238bceSAndroid Build Coastguard Worker int gotCount = deTestMultiSet_getKeyCount(set, (int16_t)i);
96*35238bceSAndroid Build Coastguard Worker
97*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 0, 1000) ? 1 : 0;
98*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 0, 500) ? 1 : 0;
99*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 0, 250) ? 1 : 0;
100*35238bceSAndroid Build Coastguard Worker
101*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == (count > 0));
102*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(count == gotCount);
103*35238bceSAndroid Build Coastguard Worker }
104*35238bceSAndroid Build Coastguard Worker
105*35238bceSAndroid Build Coastguard Worker /* Test multiset deletion rules. */
106*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 1000; i++)
107*35238bceSAndroid Build Coastguard Worker deTestMultiSet_delete(set, (int16_t)i);
108*35238bceSAndroid Build Coastguard Worker
109*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 500 + 250);
110*35238bceSAndroid Build Coastguard Worker
111*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 2000; i++)
112*35238bceSAndroid Build Coastguard Worker {
113*35238bceSAndroid Build Coastguard Worker int count = 0;
114*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
115*35238bceSAndroid Build Coastguard Worker int gotCount = deTestMultiSet_getKeyCount(set, (int16_t)i);
116*35238bceSAndroid Build Coastguard Worker
117*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 0, 500) ? 1 : 0;
118*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 0, 250) ? 1 : 0;
119*35238bceSAndroid Build Coastguard Worker
120*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == (count > 0));
121*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(count == gotCount);
122*35238bceSAndroid Build Coastguard Worker }
123*35238bceSAndroid Build Coastguard Worker
124*35238bceSAndroid Build Coastguard Worker /* Test setKeyCount(). */
125*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 250; i++)
126*35238bceSAndroid Build Coastguard Worker deTestMultiSet_setKeyCount(set, (int16_t)i, 0);
127*35238bceSAndroid Build Coastguard Worker for (i = 750; i < 1000; i++)
128*35238bceSAndroid Build Coastguard Worker deTestMultiSet_setKeyCount(set, (int16_t)i, 3);
129*35238bceSAndroid Build Coastguard Worker
130*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(deTestMultiSet_getNumElements(set) == 250 * 4);
131*35238bceSAndroid Build Coastguard Worker
132*35238bceSAndroid Build Coastguard Worker for (i = 0; i < 2000; i++)
133*35238bceSAndroid Build Coastguard Worker {
134*35238bceSAndroid Build Coastguard Worker int count = 0;
135*35238bceSAndroid Build Coastguard Worker bool found = deTestMultiSet_exists(set, (int16_t)i);
136*35238bceSAndroid Build Coastguard Worker int gotCount = deTestMultiSet_getKeyCount(set, (int16_t)i);
137*35238bceSAndroid Build Coastguard Worker
138*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 250, 500) ? 1 : 0;
139*35238bceSAndroid Build Coastguard Worker count += deInBounds32(i, 750, 1000) ? 3 : 0;
140*35238bceSAndroid Build Coastguard Worker
141*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(found == (count > 0));
142*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(gotCount == count);
143*35238bceSAndroid Build Coastguard Worker }
144*35238bceSAndroid Build Coastguard Worker
145*35238bceSAndroid Build Coastguard Worker deMemPool_destroy(pool);
146*35238bceSAndroid Build Coastguard Worker }
147