Welcome to mirror list, hosted at ThFree Co, Russian Federation.

BLI_multi_map_test.cc « blenlib « gtests « tests - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 2b64160be7e9214fb35c381b2329e0193238a9e9 (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
#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));
}