1 //===- llvm/unittest/ADT/FoldingSetTest.cpp -------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // FoldingSet unit tests.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "gtest/gtest.h"
15 #include "llvm/ADT/FoldingSet.h"
16 #include <string>
17
18 using namespace llvm;
19
20 namespace {
21
22 // Unaligned string test.
TEST(FoldingSetTest,UnalignedStringTest)23 TEST(FoldingSetTest, UnalignedStringTest) {
24 SCOPED_TRACE("UnalignedStringTest");
25
26 FoldingSetNodeID a, b;
27 // An aligned string.
28 std::string str1= "a test string";
29 a.AddString(str1);
30
31 // An unaligned string.
32 std::string str2 = ">" + str1;
33 b.AddString(str2.c_str() + 1);
34
35 EXPECT_EQ(a.ComputeHash(), b.ComputeHash());
36 }
37
38 struct TrivialPair : public FoldingSetNode {
39 unsigned Key = 0;
40 unsigned Value = 0;
TrivialPair__anonba3e33c50111::TrivialPair41 TrivialPair(unsigned K, unsigned V) : FoldingSetNode(), Key(K), Value(V) {}
42
Profile__anonba3e33c50111::TrivialPair43 void Profile(FoldingSetNodeID &ID) const {
44 ID.AddInteger(Key);
45 ID.AddInteger(Value);
46 }
47 };
48
TEST(FoldingSetTest,IDComparison)49 TEST(FoldingSetTest, IDComparison) {
50 FoldingSet<TrivialPair> Trivial;
51
52 TrivialPair T(99, 42);
53 Trivial.InsertNode(&T);
54
55 void *InsertPos = nullptr;
56 FoldingSetNodeID ID;
57 T.Profile(ID);
58 TrivialPair *N = Trivial.FindNodeOrInsertPos(ID, InsertPos);
59 EXPECT_EQ(&T, N);
60 EXPECT_EQ(nullptr, InsertPos);
61 }
62
TEST(FoldingSetTest,MissedIDComparison)63 TEST(FoldingSetTest, MissedIDComparison) {
64 FoldingSet<TrivialPair> Trivial;
65
66 TrivialPair S(100, 42);
67 TrivialPair T(99, 42);
68 Trivial.InsertNode(&T);
69
70 void *InsertPos = nullptr;
71 FoldingSetNodeID ID;
72 S.Profile(ID);
73 TrivialPair *N = Trivial.FindNodeOrInsertPos(ID, InsertPos);
74 EXPECT_EQ(nullptr, N);
75 EXPECT_NE(nullptr, InsertPos);
76 }
77
TEST(FoldingSetTest,RemoveNodeThatIsPresent)78 TEST(FoldingSetTest, RemoveNodeThatIsPresent) {
79 FoldingSet<TrivialPair> Trivial;
80
81 TrivialPair T(99, 42);
82 Trivial.InsertNode(&T);
83 EXPECT_EQ(Trivial.size(), 1U);
84
85 bool WasThere = Trivial.RemoveNode(&T);
86 EXPECT_TRUE(WasThere);
87 EXPECT_EQ(0U, Trivial.size());
88 }
89
TEST(FoldingSetTest,RemoveNodeThatIsAbsent)90 TEST(FoldingSetTest, RemoveNodeThatIsAbsent) {
91 FoldingSet<TrivialPair> Trivial;
92
93 TrivialPair T(99, 42);
94 bool WasThere = Trivial.RemoveNode(&T);
95 EXPECT_FALSE(WasThere);
96 EXPECT_EQ(0U, Trivial.size());
97 }
98
TEST(FoldingSetTest,GetOrInsertInserting)99 TEST(FoldingSetTest, GetOrInsertInserting) {
100 FoldingSet<TrivialPair> Trivial;
101
102 TrivialPair T(99, 42);
103 TrivialPair *N = Trivial.GetOrInsertNode(&T);
104 EXPECT_EQ(&T, N);
105 }
106
TEST(FoldingSetTest,GetOrInsertGetting)107 TEST(FoldingSetTest, GetOrInsertGetting) {
108 FoldingSet<TrivialPair> Trivial;
109
110 TrivialPair T(99, 42);
111 TrivialPair T2(99, 42);
112 Trivial.InsertNode(&T);
113 TrivialPair *N = Trivial.GetOrInsertNode(&T2);
114 EXPECT_EQ(&T, N);
115 }
116
TEST(FoldingSetTest,InsertAtPos)117 TEST(FoldingSetTest, InsertAtPos) {
118 FoldingSet<TrivialPair> Trivial;
119
120 void *InsertPos = nullptr;
121 TrivialPair Finder(99, 42);
122 FoldingSetNodeID ID;
123 Finder.Profile(ID);
124 Trivial.FindNodeOrInsertPos(ID, InsertPos);
125
126 TrivialPair T(99, 42);
127 Trivial.InsertNode(&T, InsertPos);
128 EXPECT_EQ(1U, Trivial.size());
129 }
130
TEST(FoldingSetTest,EmptyIsTrue)131 TEST(FoldingSetTest, EmptyIsTrue) {
132 FoldingSet<TrivialPair> Trivial;
133 EXPECT_TRUE(Trivial.empty());
134 }
135
TEST(FoldingSetTest,EmptyIsFalse)136 TEST(FoldingSetTest, EmptyIsFalse) {
137 FoldingSet<TrivialPair> Trivial;
138 TrivialPair T(99, 42);
139 Trivial.InsertNode(&T);
140 EXPECT_FALSE(Trivial.empty());
141 }
142
TEST(FoldingSetTest,ClearOnEmpty)143 TEST(FoldingSetTest, ClearOnEmpty) {
144 FoldingSet<TrivialPair> Trivial;
145 Trivial.clear();
146 EXPECT_TRUE(Trivial.empty());
147 }
148
TEST(FoldingSetTest,ClearOnNonEmpty)149 TEST(FoldingSetTest, ClearOnNonEmpty) {
150 FoldingSet<TrivialPair> Trivial;
151 TrivialPair T(99, 42);
152 Trivial.InsertNode(&T);
153 Trivial.clear();
154 EXPECT_TRUE(Trivial.empty());
155 }
156
TEST(FoldingSetTest,CapacityLargerThanReserve)157 TEST(FoldingSetTest, CapacityLargerThanReserve) {
158 FoldingSet<TrivialPair> Trivial;
159 auto OldCapacity = Trivial.capacity();
160 Trivial.reserve(OldCapacity + 1);
161 EXPECT_GE(Trivial.capacity(), OldCapacity + 1);
162 }
163
TEST(FoldingSetTest,SmallReserveChangesNothing)164 TEST(FoldingSetTest, SmallReserveChangesNothing) {
165 FoldingSet<TrivialPair> Trivial;
166 auto OldCapacity = Trivial.capacity();
167 Trivial.reserve(OldCapacity - 1);
168 EXPECT_EQ(Trivial.capacity(), OldCapacity);
169 }
170
171 }
172
173