About Social Code
aboutsummaryrefslogtreecommitdiff
path: root/src/util/tests/sparse_bitset_test.cpp
blob: 00de3d0bc657aa35db204fcd6501ffa351f78d9f (plain)
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
 * Copyright © 2025 Valve Corporation
 *
 * SPDX-License-Identifier: MIT
 */

#include <gtest/gtest.h>
#include "util/sparse_bitset.h"


TEST(sparse_bitset, tree)
{
   struct u_sparse_bitset set;
   u_sparse_bitset_init(&set, 1048577, NULL);

   u_sparse_bitset_set(&set, 65535);
   u_sparse_bitset_set(&set, 1048576);

   unsigned num_nodes = 0;
   rb_tree_foreach(struct u_sparse_bitset_node, _, &set.tree, node) {
      ++num_nodes;
   }
   EXPECT_EQ(num_nodes, 2);

   u_sparse_bitset_free(&set);
}

TEST(sparse_bitset, set_clear)
{
   struct u_sparse_bitset set;
   u_sparse_bitset_init(&set, 1048577, NULL);

   u_sparse_bitset_set(&set, 65535);
   u_sparse_bitset_set(&set, 1048576);
   u_sparse_bitset_set(&set, 16383);

   EXPECT_EQ(u_sparse_bitset_test(&set, 128), false);
   EXPECT_EQ(u_sparse_bitset_test(&set, 65535), true);
   EXPECT_EQ(u_sparse_bitset_test(&set, 16383), true);

   u_sparse_bitset_clear(&set, 1236749);
   u_sparse_bitset_clear(&set, 65535);

   EXPECT_EQ(u_sparse_bitset_test(&set, 65535), false);

   u_sparse_bitset_free(&set);
}

TEST(sparse_bitset, set_dup)
{
   struct u_sparse_bitset set;
   u_sparse_bitset_init(&set, 1048577, NULL);

   u_sparse_bitset_set(&set, 65535);
   u_sparse_bitset_set(&set, 1048576);

   struct u_sparse_bitset set2;
   u_sparse_bitset_dup(&set2, &set);

   u_sparse_bitset_clear(&set, 65535);

   EXPECT_EQ(u_sparse_bitset_test(&set2, 128), false);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 65535), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 1048576), true);

   u_sparse_bitset_free(&set);
   u_sparse_bitset_free(&set2);
}

TEST(sparse_bitset, set_merge)
{
   struct u_sparse_bitset set;
   u_sparse_bitset_init(&set, 1048577, NULL);

   u_sparse_bitset_set(&set, 65535);
   u_sparse_bitset_set(&set, 1048576);

   struct u_sparse_bitset set2;
   u_sparse_bitset_init(&set2, 1048577, NULL);
   u_sparse_bitset_set(&set2, 128);
   u_sparse_bitset_set(&set2, 16383);

   EXPECT_EQ(u_sparse_bitset_merge(&set2, &set), true);

   u_sparse_bitset_clear(&set, 65535);

   EXPECT_EQ(u_sparse_bitset_test(&set2, 128), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 16383), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 65535), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 1048576), true);

   EXPECT_EQ(u_sparse_bitset_merge(&set2, &set), false);

   EXPECT_EQ(u_sparse_bitset_test(&set2, 128), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 16383), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 65535), true);
   EXPECT_EQ(u_sparse_bitset_test(&set2, 1048576), true);

   u_sparse_bitset_free(&set);
   u_sparse_bitset_free(&set2);
}

TEST(sparse_bitset, set_foreach)
{
   struct u_sparse_bitset set;
   u_sparse_bitset_init(&set, 1048577, NULL);

   u_sparse_bitset_set(&set, 65535);
   u_sparse_bitset_set(&set, 1048576);
   u_sparse_bitset_set(&set, 16383);
   u_sparse_bitset_set(&set, 19);
   u_sparse_bitset_set(&set, 422);
   u_sparse_bitset_set(&set, 65539);

   uint32_t arr[] = {19, 422, 16383, 65535, 65539, 1048576};
   unsigned i = 0;

   U_SPARSE_BITSET_FOREACH_SET(&set, it) {
      EXPECT_LE(i, ARRAY_SIZE(arr));
      EXPECT_EQ(it, arr[i]);
      ++i;
   }

   EXPECT_EQ(i, ARRAY_SIZE(arr));

   u_sparse_bitset_free(&set);
}