194 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			C++
		
	
	
	
//===- llvm/unittest/ADT/FoldingSetTest.cpp -------------------------------===//
 | 
						|
//
 | 
						|
//                     The LLVM Compiler Infrastructure
 | 
						|
//
 | 
						|
// This file is distributed under the University of Illinois Open Source
 | 
						|
// License. See LICENSE.TXT for details.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
//
 | 
						|
// FoldingSet unit tests.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#include "llvm/ADT/FoldingSet.h"
 | 
						|
#include "gtest/gtest.h"
 | 
						|
#include <string>
 | 
						|
 | 
						|
using namespace llvm;
 | 
						|
 | 
						|
namespace {
 | 
						|
 | 
						|
// Unaligned string test.
 | 
						|
TEST(FoldingSetTest, UnalignedStringTest) {
 | 
						|
  SCOPED_TRACE("UnalignedStringTest");
 | 
						|
 | 
						|
  FoldingSetNodeID a, b;
 | 
						|
  // An aligned string.
 | 
						|
  std::string str1= "a test string";
 | 
						|
  a.AddString(str1);
 | 
						|
 | 
						|
  // An unaligned string.
 | 
						|
  std::string str2 = ">" + str1;
 | 
						|
  b.AddString(str2.c_str() + 1);
 | 
						|
 | 
						|
  EXPECT_EQ(a.ComputeHash(), b.ComputeHash());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, LongLongComparison) {
 | 
						|
  struct LongLongContainer : FoldingSetNode {
 | 
						|
    unsigned long long A, B;
 | 
						|
    LongLongContainer(unsigned long long A, unsigned long long B)
 | 
						|
        : A(A), B(B) {}
 | 
						|
    void Profile(FoldingSetNodeID &ID) const {
 | 
						|
      ID.AddInteger(A);
 | 
						|
      ID.AddInteger(B);
 | 
						|
    }
 | 
						|
  };
 | 
						|
 | 
						|
  LongLongContainer C1((1ULL << 32) + 1, 1ULL);
 | 
						|
  LongLongContainer C2(1ULL, (1ULL << 32) + 1);
 | 
						|
 | 
						|
  FoldingSet<LongLongContainer> Set;
 | 
						|
 | 
						|
  EXPECT_EQ(&C1, Set.GetOrInsertNode(&C1));
 | 
						|
  EXPECT_EQ(&C2, Set.GetOrInsertNode(&C2));
 | 
						|
  EXPECT_EQ(2U, Set.size());
 | 
						|
}
 | 
						|
 | 
						|
struct TrivialPair : public FoldingSetNode {
 | 
						|
  unsigned Key = 0;
 | 
						|
  unsigned Value = 0;
 | 
						|
  TrivialPair(unsigned K, unsigned V) : FoldingSetNode(), Key(K), Value(V) {}
 | 
						|
 | 
						|
  void Profile(FoldingSetNodeID &ID) const {
 | 
						|
    ID.AddInteger(Key);
 | 
						|
    ID.AddInteger(Value);
 | 
						|
  }
 | 
						|
};
 | 
						|
 | 
						|
TEST(FoldingSetTest, IDComparison) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
 | 
						|
  void *InsertPos = nullptr;
 | 
						|
  FoldingSetNodeID ID;
 | 
						|
  T.Profile(ID);
 | 
						|
  TrivialPair *N = Trivial.FindNodeOrInsertPos(ID, InsertPos);
 | 
						|
  EXPECT_EQ(&T, N);
 | 
						|
  EXPECT_EQ(nullptr, InsertPos);
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, MissedIDComparison) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair S(100, 42);
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
 | 
						|
  void *InsertPos = nullptr;
 | 
						|
  FoldingSetNodeID ID;
 | 
						|
  S.Profile(ID);
 | 
						|
  TrivialPair *N = Trivial.FindNodeOrInsertPos(ID, InsertPos);
 | 
						|
  EXPECT_EQ(nullptr, N);
 | 
						|
  EXPECT_NE(nullptr, InsertPos);
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, RemoveNodeThatIsPresent) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
  EXPECT_EQ(Trivial.size(), 1U);
 | 
						|
 | 
						|
  bool WasThere = Trivial.RemoveNode(&T);
 | 
						|
  EXPECT_TRUE(WasThere);
 | 
						|
  EXPECT_EQ(0U, Trivial.size());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, RemoveNodeThatIsAbsent) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  bool WasThere = Trivial.RemoveNode(&T);
 | 
						|
  EXPECT_FALSE(WasThere);
 | 
						|
  EXPECT_EQ(0U, Trivial.size());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, GetOrInsertInserting) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  TrivialPair *N = Trivial.GetOrInsertNode(&T);
 | 
						|
  EXPECT_EQ(&T, N);
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, GetOrInsertGetting) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  TrivialPair T2(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
  TrivialPair *N = Trivial.GetOrInsertNode(&T2);
 | 
						|
  EXPECT_EQ(&T, N);
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, InsertAtPos) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
 | 
						|
  void *InsertPos = nullptr;
 | 
						|
  TrivialPair Finder(99, 42);
 | 
						|
  FoldingSetNodeID ID;
 | 
						|
  Finder.Profile(ID);
 | 
						|
  Trivial.FindNodeOrInsertPos(ID, InsertPos);
 | 
						|
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T, InsertPos);
 | 
						|
  EXPECT_EQ(1U, Trivial.size());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, EmptyIsTrue) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  EXPECT_TRUE(Trivial.empty());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, EmptyIsFalse) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
  EXPECT_FALSE(Trivial.empty());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, ClearOnEmpty) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  Trivial.clear();
 | 
						|
  EXPECT_TRUE(Trivial.empty());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, ClearOnNonEmpty) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  TrivialPair T(99, 42);
 | 
						|
  Trivial.InsertNode(&T);
 | 
						|
  Trivial.clear();
 | 
						|
  EXPECT_TRUE(Trivial.empty());
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, CapacityLargerThanReserve) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  auto OldCapacity = Trivial.capacity();
 | 
						|
  Trivial.reserve(OldCapacity + 1);
 | 
						|
  EXPECT_GE(Trivial.capacity(), OldCapacity + 1);
 | 
						|
}
 | 
						|
 | 
						|
TEST(FoldingSetTest, SmallReserveChangesNothing) {
 | 
						|
  FoldingSet<TrivialPair> Trivial;
 | 
						|
  auto OldCapacity = Trivial.capacity();
 | 
						|
  Trivial.reserve(OldCapacity - 1);
 | 
						|
  EXPECT_EQ(Trivial.capacity(), OldCapacity);
 | 
						|
}
 | 
						|
 | 
						|
}
 | 
						|
 |