1 //===- unittest/ADT/MapVectorTest.cpp - MapVector unit tests ----*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #include "llvm/ADT/MapVector.h"
10 #include "llvm/ADT/iterator_range.h"
11 #include "gtest/gtest.h"
16 TEST(MapVectorTest
, swap
) {
17 MapVector
<int, int> MV1
, MV2
;
18 std::pair
<MapVector
<int, int>::iterator
, bool> R
;
20 R
= MV1
.insert(std::make_pair(1, 2));
21 ASSERT_EQ(R
.first
, MV1
.begin());
22 EXPECT_EQ(R
.first
->first
, 1);
23 EXPECT_EQ(R
.first
->second
, 2);
24 EXPECT_TRUE(R
.second
);
26 EXPECT_FALSE(MV1
.empty());
27 EXPECT_TRUE(MV2
.empty());
29 EXPECT_TRUE(MV1
.empty());
30 EXPECT_FALSE(MV2
.empty());
33 ASSERT_EQ(MV1
.end(), I
);
36 ASSERT_EQ(I
, MV2
.begin());
37 EXPECT_EQ(I
->first
, 1);
38 EXPECT_EQ(I
->second
, 2);
41 TEST(MapVectorTest
, insert_pop
) {
42 MapVector
<int, int> MV
;
43 std::pair
<MapVector
<int, int>::iterator
, bool> R
;
45 R
= MV
.insert(std::make_pair(1, 2));
46 ASSERT_EQ(R
.first
, MV
.begin());
47 EXPECT_EQ(R
.first
->first
, 1);
48 EXPECT_EQ(R
.first
->second
, 2);
49 EXPECT_TRUE(R
.second
);
51 R
= MV
.insert(std::make_pair(1, 3));
52 ASSERT_EQ(R
.first
, MV
.begin());
53 EXPECT_EQ(R
.first
->first
, 1);
54 EXPECT_EQ(R
.first
->second
, 2);
55 EXPECT_FALSE(R
.second
);
57 R
= MV
.insert(std::make_pair(4, 5));
58 ASSERT_NE(R
.first
, MV
.end());
59 EXPECT_EQ(R
.first
->first
, 4);
60 EXPECT_EQ(R
.first
->second
, 5);
61 EXPECT_TRUE(R
.second
);
63 EXPECT_EQ(MV
.size(), 2u);
68 EXPECT_EQ(MV
.size(), 1u);
71 R
= MV
.insert(std::make_pair(4, 7));
72 ASSERT_NE(R
.first
, MV
.end());
73 EXPECT_EQ(R
.first
->first
, 4);
74 EXPECT_EQ(R
.first
->second
, 7);
75 EXPECT_TRUE(R
.second
);
77 EXPECT_EQ(MV
.size(), 2u);
82 TEST(MapVectorTest
, erase
) {
83 MapVector
<int, int> MV
;
85 MV
.insert(std::make_pair(1, 2));
86 MV
.insert(std::make_pair(3, 4));
87 MV
.insert(std::make_pair(5, 6));
88 ASSERT_EQ(MV
.size(), 3u);
91 ASSERT_EQ(MV
.size(), 2u);
92 ASSERT_EQ(MV
.find(1), MV
.end());
96 ASSERT_EQ(MV
.erase(3), 1u);
97 ASSERT_EQ(MV
.size(), 1u);
98 ASSERT_EQ(MV
.find(3), MV
.end());
101 ASSERT_EQ(MV
.erase(79), 0u);
102 ASSERT_EQ(MV
.size(), 1u);
105 TEST(MapVectorTest
, remove_if
) {
106 MapVector
<int, int> MV
;
108 MV
.insert(std::make_pair(1, 11));
109 MV
.insert(std::make_pair(2, 12));
110 MV
.insert(std::make_pair(3, 13));
111 MV
.insert(std::make_pair(4, 14));
112 MV
.insert(std::make_pair(5, 15));
113 MV
.insert(std::make_pair(6, 16));
114 ASSERT_EQ(MV
.size(), 6u);
116 MV
.remove_if([](const std::pair
<int, int> &Val
) { return Val
.second
% 2; });
117 ASSERT_EQ(MV
.size(), 3u);
118 ASSERT_EQ(MV
.find(1), MV
.end());
119 ASSERT_EQ(MV
.find(3), MV
.end());
120 ASSERT_EQ(MV
.find(5), MV
.end());
121 ASSERT_EQ(MV
[2], 12);
122 ASSERT_EQ(MV
[4], 14);
123 ASSERT_EQ(MV
[6], 16);
126 TEST(MapVectorTest
, iteration_test
) {
127 MapVector
<int, int> MV
;
129 MV
.insert(std::make_pair(1, 11));
130 MV
.insert(std::make_pair(2, 12));
131 MV
.insert(std::make_pair(3, 13));
132 MV
.insert(std::make_pair(4, 14));
133 MV
.insert(std::make_pair(5, 15));
134 MV
.insert(std::make_pair(6, 16));
135 ASSERT_EQ(MV
.size(), 6u);
138 for (auto P
: make_range(MV
.begin(), MV
.end())) {
139 ASSERT_EQ(P
.first
, count
);
144 for (auto P
: make_range(MV
.rbegin(), MV
.rend())) {
145 ASSERT_EQ(P
.first
, count
);
150 TEST(MapVectorTest
, NonCopyable
) {
151 MapVector
<int, std::unique_ptr
<int>> MV
;
152 MV
.insert(std::make_pair(1, llvm::make_unique
<int>(1)));
153 MV
.insert(std::make_pair(2, llvm::make_unique
<int>(2)));
155 ASSERT_EQ(MV
.count(1), 1u);
156 ASSERT_EQ(*MV
.find(2)->second
, 2);
159 template <class IntType
> struct MapVectorMappedTypeTest
: ::testing::Test
{
160 using int_type
= IntType
;
163 using MapIntTypes
= ::testing::Types
<int, long, long long, unsigned,
164 unsigned long, unsigned long long>;
165 TYPED_TEST_CASE(MapVectorMappedTypeTest
, MapIntTypes
);
167 TYPED_TEST(MapVectorMappedTypeTest
, DifferentDenseMap
) {
168 // Test that using a map with a mapped type other than 'unsigned' compiles
170 using IntType
= typename
TestFixture::int_type
;
171 using MapVectorType
= MapVector
<int, int, DenseMap
<int, IntType
>>;
174 std::pair
<typename
MapVectorType::iterator
, bool> R
;
176 R
= MV
.insert(std::make_pair(1, 2));
177 ASSERT_EQ(R
.first
, MV
.begin());
178 EXPECT_EQ(R
.first
->first
, 1);
179 EXPECT_EQ(R
.first
->second
, 2);
180 EXPECT_TRUE(R
.second
);
182 const std::pair
<int, int> Elem(1, 3);
184 ASSERT_EQ(R
.first
, MV
.begin());
185 EXPECT_EQ(R
.first
->first
, 1);
186 EXPECT_EQ(R
.first
->second
, 2);
187 EXPECT_FALSE(R
.second
);
193 EXPECT_EQ(MV
.size(), 2u);
198 TEST(SmallMapVectorSmallTest
, insert_pop
) {
199 SmallMapVector
<int, int, 32> MV
;
200 std::pair
<SmallMapVector
<int, int, 32>::iterator
, bool> R
;
202 R
= MV
.insert(std::make_pair(1, 2));
203 ASSERT_EQ(R
.first
, MV
.begin());
204 EXPECT_EQ(R
.first
->first
, 1);
205 EXPECT_EQ(R
.first
->second
, 2);
206 EXPECT_TRUE(R
.second
);
208 R
= MV
.insert(std::make_pair(1, 3));
209 ASSERT_EQ(R
.first
, MV
.begin());
210 EXPECT_EQ(R
.first
->first
, 1);
211 EXPECT_EQ(R
.first
->second
, 2);
212 EXPECT_FALSE(R
.second
);
214 R
= MV
.insert(std::make_pair(4, 5));
215 ASSERT_NE(R
.first
, MV
.end());
216 EXPECT_EQ(R
.first
->first
, 4);
217 EXPECT_EQ(R
.first
->second
, 5);
218 EXPECT_TRUE(R
.second
);
220 EXPECT_EQ(MV
.size(), 2u);
225 EXPECT_EQ(MV
.size(), 1u);
228 R
= MV
.insert(std::make_pair(4, 7));
229 ASSERT_NE(R
.first
, MV
.end());
230 EXPECT_EQ(R
.first
->first
, 4);
231 EXPECT_EQ(R
.first
->second
, 7);
232 EXPECT_TRUE(R
.second
);
234 EXPECT_EQ(MV
.size(), 2u);
239 TEST(SmallMapVectorSmallTest
, erase
) {
240 SmallMapVector
<int, int, 32> MV
;
242 MV
.insert(std::make_pair(1, 2));
243 MV
.insert(std::make_pair(3, 4));
244 MV
.insert(std::make_pair(5, 6));
245 ASSERT_EQ(MV
.size(), 3u);
247 MV
.erase(MV
.find(1));
248 ASSERT_EQ(MV
.size(), 2u);
249 ASSERT_EQ(MV
.find(1), MV
.end());
253 ASSERT_EQ(MV
.erase(3), 1u);
254 ASSERT_EQ(MV
.size(), 1u);
255 ASSERT_EQ(MV
.find(3), MV
.end());
258 ASSERT_EQ(MV
.erase(79), 0u);
259 ASSERT_EQ(MV
.size(), 1u);
262 TEST(SmallMapVectorSmallTest
, remove_if
) {
263 SmallMapVector
<int, int, 32> MV
;
265 MV
.insert(std::make_pair(1, 11));
266 MV
.insert(std::make_pair(2, 12));
267 MV
.insert(std::make_pair(3, 13));
268 MV
.insert(std::make_pair(4, 14));
269 MV
.insert(std::make_pair(5, 15));
270 MV
.insert(std::make_pair(6, 16));
271 ASSERT_EQ(MV
.size(), 6u);
273 MV
.remove_if([](const std::pair
<int, int> &Val
) { return Val
.second
% 2; });
274 ASSERT_EQ(MV
.size(), 3u);
275 ASSERT_EQ(MV
.find(1), MV
.end());
276 ASSERT_EQ(MV
.find(3), MV
.end());
277 ASSERT_EQ(MV
.find(5), MV
.end());
278 ASSERT_EQ(MV
[2], 12);
279 ASSERT_EQ(MV
[4], 14);
280 ASSERT_EQ(MV
[6], 16);
283 TEST(SmallMapVectorSmallTest
, iteration_test
) {
284 SmallMapVector
<int, int, 32> MV
;
286 MV
.insert(std::make_pair(1, 11));
287 MV
.insert(std::make_pair(2, 12));
288 MV
.insert(std::make_pair(3, 13));
289 MV
.insert(std::make_pair(4, 14));
290 MV
.insert(std::make_pair(5, 15));
291 MV
.insert(std::make_pair(6, 16));
292 ASSERT_EQ(MV
.size(), 6u);
295 for (auto P
: make_range(MV
.begin(), MV
.end())) {
296 ASSERT_EQ(P
.first
, count
);
301 for (auto P
: make_range(MV
.rbegin(), MV
.rend())) {
302 ASSERT_EQ(P
.first
, count
);
307 TEST(SmallMapVectorSmallTest
, NonCopyable
) {
308 SmallMapVector
<int, std::unique_ptr
<int>, 8> MV
;
309 MV
.insert(std::make_pair(1, llvm::make_unique
<int>(1)));
310 MV
.insert(std::make_pair(2, llvm::make_unique
<int>(2)));
312 ASSERT_EQ(MV
.count(1), 1u);
313 ASSERT_EQ(*MV
.find(2)->second
, 2);
316 TEST(SmallMapVectorLargeTest
, insert_pop
) {
317 SmallMapVector
<int, int, 1> MV
;
318 std::pair
<SmallMapVector
<int, int, 1>::iterator
, bool> R
;
320 R
= MV
.insert(std::make_pair(1, 2));
321 ASSERT_EQ(R
.first
, MV
.begin());
322 EXPECT_EQ(R
.first
->first
, 1);
323 EXPECT_EQ(R
.first
->second
, 2);
324 EXPECT_TRUE(R
.second
);
326 R
= MV
.insert(std::make_pair(1, 3));
327 ASSERT_EQ(R
.first
, MV
.begin());
328 EXPECT_EQ(R
.first
->first
, 1);
329 EXPECT_EQ(R
.first
->second
, 2);
330 EXPECT_FALSE(R
.second
);
332 R
= MV
.insert(std::make_pair(4, 5));
333 ASSERT_NE(R
.first
, MV
.end());
334 EXPECT_EQ(R
.first
->first
, 4);
335 EXPECT_EQ(R
.first
->second
, 5);
336 EXPECT_TRUE(R
.second
);
338 EXPECT_EQ(MV
.size(), 2u);
343 EXPECT_EQ(MV
.size(), 1u);
346 R
= MV
.insert(std::make_pair(4, 7));
347 ASSERT_NE(R
.first
, MV
.end());
348 EXPECT_EQ(R
.first
->first
, 4);
349 EXPECT_EQ(R
.first
->second
, 7);
350 EXPECT_TRUE(R
.second
);
352 EXPECT_EQ(MV
.size(), 2u);
357 TEST(SmallMapVectorLargeTest
, erase
) {
358 SmallMapVector
<int, int, 1> MV
;
360 MV
.insert(std::make_pair(1, 2));
361 MV
.insert(std::make_pair(3, 4));
362 MV
.insert(std::make_pair(5, 6));
363 ASSERT_EQ(MV
.size(), 3u);
365 MV
.erase(MV
.find(1));
366 ASSERT_EQ(MV
.size(), 2u);
367 ASSERT_EQ(MV
.find(1), MV
.end());
371 ASSERT_EQ(MV
.erase(3), 1u);
372 ASSERT_EQ(MV
.size(), 1u);
373 ASSERT_EQ(MV
.find(3), MV
.end());
376 ASSERT_EQ(MV
.erase(79), 0u);
377 ASSERT_EQ(MV
.size(), 1u);
380 TEST(SmallMapVectorLargeTest
, remove_if
) {
381 SmallMapVector
<int, int, 1> MV
;
383 MV
.insert(std::make_pair(1, 11));
384 MV
.insert(std::make_pair(2, 12));
385 MV
.insert(std::make_pair(3, 13));
386 MV
.insert(std::make_pair(4, 14));
387 MV
.insert(std::make_pair(5, 15));
388 MV
.insert(std::make_pair(6, 16));
389 ASSERT_EQ(MV
.size(), 6u);
391 MV
.remove_if([](const std::pair
<int, int> &Val
) { return Val
.second
% 2; });
392 ASSERT_EQ(MV
.size(), 3u);
393 ASSERT_EQ(MV
.find(1), MV
.end());
394 ASSERT_EQ(MV
.find(3), MV
.end());
395 ASSERT_EQ(MV
.find(5), MV
.end());
396 ASSERT_EQ(MV
[2], 12);
397 ASSERT_EQ(MV
[4], 14);
398 ASSERT_EQ(MV
[6], 16);
401 TEST(SmallMapVectorLargeTest
, iteration_test
) {
402 SmallMapVector
<int, int, 1> MV
;
404 MV
.insert(std::make_pair(1, 11));
405 MV
.insert(std::make_pair(2, 12));
406 MV
.insert(std::make_pair(3, 13));
407 MV
.insert(std::make_pair(4, 14));
408 MV
.insert(std::make_pair(5, 15));
409 MV
.insert(std::make_pair(6, 16));
410 ASSERT_EQ(MV
.size(), 6u);
413 for (auto P
: make_range(MV
.begin(), MV
.end())) {
414 ASSERT_EQ(P
.first
, count
);
419 for (auto P
: make_range(MV
.rbegin(), MV
.rend())) {
420 ASSERT_EQ(P
.first
, count
);