|  | //===- llvm/unittest/ADT/SmallSetTest.cpp ------------------------------===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // SmallSet unit tests. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #include "llvm/ADT/SmallSet.h" | 
|  | #include "gtest/gtest.h" | 
|  | #include <string> | 
|  |  | 
|  | using namespace llvm; | 
|  |  | 
|  | TEST(SmallSetTest, Insert) { | 
|  |  | 
|  | SmallSet<int, 4> s1; | 
|  |  | 
|  | for (int i = 0; i < 4; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | for (int i = 0; i < 4; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | EXPECT_EQ(4u, s1.size()); | 
|  |  | 
|  | for (int i = 0; i < 4; i++) | 
|  | EXPECT_EQ(1u, s1.count(i)); | 
|  |  | 
|  | EXPECT_EQ(0u, s1.count(4)); | 
|  | } | 
|  |  | 
|  | TEST(SmallSetTest, Grow) { | 
|  | SmallSet<int, 4> s1; | 
|  |  | 
|  | for (int i = 0; i < 8; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | EXPECT_EQ(8u, s1.size()); | 
|  |  | 
|  | for (int i = 0; i < 8; i++) | 
|  | EXPECT_EQ(1u, s1.count(i)); | 
|  |  | 
|  | EXPECT_EQ(0u, s1.count(8)); | 
|  | } | 
|  |  | 
|  | TEST(SmallSetTest, Erase) { | 
|  | SmallSet<int, 4> s1; | 
|  |  | 
|  | for (int i = 0; i < 8; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | EXPECT_EQ(8u, s1.size()); | 
|  |  | 
|  | // Remove elements one by one and check if all other elements are still there. | 
|  | for (int i = 0; i < 8; i++) { | 
|  | EXPECT_EQ(1u, s1.count(i)); | 
|  | EXPECT_TRUE(s1.erase(i)); | 
|  | EXPECT_EQ(0u, s1.count(i)); | 
|  | EXPECT_EQ(8u - i - 1, s1.size()); | 
|  | for (int j = i + 1; j < 8; j++) | 
|  | EXPECT_EQ(1u, s1.count(j)); | 
|  | } | 
|  |  | 
|  | EXPECT_EQ(0u, s1.count(8)); | 
|  | } | 
|  |  | 
|  | TEST(SmallSetTest, IteratorInt) { | 
|  | SmallSet<int, 4> s1; | 
|  |  | 
|  | // Test the 'small' case. | 
|  | for (int i = 0; i < 3; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | std::vector<int> V(s1.begin(), s1.end()); | 
|  | // Make sure the elements are in the expected order. | 
|  | std::sort(V.begin(), V.end()); | 
|  | for (int i = 0; i < 3; i++) | 
|  | EXPECT_EQ(i, V[i]); | 
|  |  | 
|  | // Test the 'big' case by adding a few more elements to switch to std::set | 
|  | // internally. | 
|  | for (int i = 3; i < 6; i++) | 
|  | s1.insert(i); | 
|  |  | 
|  | V.assign(s1.begin(), s1.end()); | 
|  | // Make sure the elements are in the expected order. | 
|  | std::sort(V.begin(), V.end()); | 
|  | for (int i = 0; i < 6; i++) | 
|  | EXPECT_EQ(i, V[i]); | 
|  | } | 
|  |  | 
|  | TEST(SmallSetTest, IteratorString) { | 
|  | // Test SmallSetIterator for SmallSet with a type with non-trivial | 
|  | // ctors/dtors. | 
|  | SmallSet<std::string, 2> s1; | 
|  |  | 
|  | s1.insert("str 1"); | 
|  | s1.insert("str 2"); | 
|  | s1.insert("str 1"); | 
|  |  | 
|  | std::vector<std::string> V(s1.begin(), s1.end()); | 
|  | std::sort(V.begin(), V.end()); | 
|  | EXPECT_EQ(2u, s1.size()); | 
|  | EXPECT_EQ("str 1", V[0]); | 
|  | EXPECT_EQ("str 2", V[1]); | 
|  |  | 
|  | s1.insert("str 4"); | 
|  | s1.insert("str 0"); | 
|  | s1.insert("str 4"); | 
|  |  | 
|  | V.assign(s1.begin(), s1.end()); | 
|  | // Make sure the elements are in the expected order. | 
|  | std::sort(V.begin(), V.end()); | 
|  | EXPECT_EQ(4u, s1.size()); | 
|  | EXPECT_EQ("str 0", V[0]); | 
|  | EXPECT_EQ("str 1", V[1]); | 
|  | EXPECT_EQ("str 2", V[2]); | 
|  | EXPECT_EQ("str 4", V[3]); | 
|  | } | 
|  |  | 
|  | TEST(SmallSetTest, IteratorIncMoveCopy) { | 
|  | // Test SmallSetIterator for SmallSet with a type with non-trivial | 
|  | // ctors/dtors. | 
|  | SmallSet<std::string, 2> s1; | 
|  |  | 
|  | s1.insert("str 1"); | 
|  | s1.insert("str 2"); | 
|  |  | 
|  | auto Iter = s1.begin(); | 
|  | EXPECT_EQ("str 1", *Iter); | 
|  | ++Iter; | 
|  | EXPECT_EQ("str 2", *Iter); | 
|  |  | 
|  | s1.insert("str 4"); | 
|  | s1.insert("str 0"); | 
|  | auto Iter2 = s1.begin(); | 
|  | Iter = std::move(Iter2); | 
|  | EXPECT_EQ("str 0", *Iter); | 
|  |  | 
|  | auto Iter3 = s1.end(); | 
|  | Iter3 = Iter2; | 
|  | EXPECT_EQ(Iter3, Iter2); | 
|  | } |