xref: /aosp_15_r20/external/deqp/framework/delibs/depool/dePoolMultiSet.c (revision 35238bce31c2a825756842865a792f8cf7f89930)
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