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
|
#include "BLI_multi_map.h"
#include "testing/testing.h"
using namespace BLI;
using IntMultiMap = MultiMap<int, int>;
TEST(multi_map, DefaultConstructor)
{
IntMultiMap map;
EXPECT_EQ(map.key_amount(), 0);
}
TEST(multi_map, AddNewSingle)
{
IntMultiMap map;
map.add_new(2, 5);
EXPECT_EQ(map.key_amount(), 1);
EXPECT_TRUE(map.contains(2));
EXPECT_FALSE(map.contains(5));
EXPECT_EQ(map.lookup(2)[0], 5);
}
TEST(multi_map, AddMultipleforSameKey)
{
IntMultiMap map;
map.add(3, 5);
map.add(3, 1);
map.add(3, 7);
EXPECT_EQ(map.key_amount(), 1);
EXPECT_EQ(map.lookup(3).size(), 3);
EXPECT_EQ(map.lookup(3)[0], 5);
EXPECT_EQ(map.lookup(3)[1], 1);
EXPECT_EQ(map.lookup(3)[2], 7);
}
TEST(multi_map, AddMany)
{
IntMultiMap map;
for (uint i = 0; i < 100; i++) {
int key = i % 10;
map.add(key, i);
}
EXPECT_EQ(map.key_amount(), 10);
EXPECT_TRUE(map.contains(3));
EXPECT_FALSE(map.contains(11));
EXPECT_EQ(map.lookup(2)[4], 42);
EXPECT_EQ(map.lookup(6)[1], 16);
EXPECT_EQ(map.lookup(7).size(), 10);
}
TEST(multi_map, AddMultiple)
{
IntMultiMap map;
map.add_multiple(2, {6, 7, 8});
map.add_multiple(3, {1, 2});
map.add_multiple(2, {9, 1});
EXPECT_EQ(map.key_amount(), 2);
EXPECT_EQ(map.lookup_default(2).size(), 5);
EXPECT_EQ(map.lookup_default(3).size(), 2);
EXPECT_EQ(map.lookup_default(2)[0], 6);
EXPECT_EQ(map.lookup_default(2)[1], 7);
EXPECT_EQ(map.lookup_default(2)[2], 8);
EXPECT_EQ(map.lookup_default(2)[3], 9);
EXPECT_EQ(map.lookup_default(2)[4], 1);
}
TEST(multi_map, AddMultipleNew)
{
IntMultiMap map;
map.add_multiple_new(3, {6, 7, 8});
map.add_multiple_new(2, {1, 2, 5, 7});
EXPECT_EQ(map.key_amount(), 2);
EXPECT_TRUE(map.contains(3));
EXPECT_TRUE(map.contains(2));
EXPECT_TRUE(map.lookup(2).contains(2));
EXPECT_FALSE(map.lookup(2).contains(3));
}
TEST(multi_map, ValuesForKey)
{
IntMultiMap map;
map.add(3, 5);
map.add(3, 7);
map.add(3, 8);
map.add(4, 2);
map.add(4, 3);
EXPECT_EQ(map.value_amount(3), 3);
EXPECT_EQ(map.value_amount(4), 2);
}
TEST(multi_map, Keys)
{
IntMultiMap map;
map.add(3, 6);
map.add(3, 3);
map.add(3, 4);
map.add(4, 1);
map.add(2, 1);
Vector<int> values;
for (auto value : map.keys()) {
values.append(value);
}
EXPECT_EQ(values.size(), 3);
EXPECT_TRUE(values.contains(3));
EXPECT_TRUE(values.contains(4));
EXPECT_TRUE(values.contains(2));
}
|