2018-06-09 05:14:49 +08:00
|
|
|
//===- 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"
|
2018-07-24 18:32:54 +08:00
|
|
|
#include <string>
|
2018-06-09 05:14:49 +08:00
|
|
|
|
|
|
|
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));
|
|
|
|
}
|
2018-07-24 18:32:54 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|