2016-06-30 10:32:20 +08:00
|
|
|
//===- llvm/unittest/ADT/PriorityWorklist.cpp -----------------------------===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2016-06-30 10:32:20 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// PriorityWorklist unit tests.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "llvm/ADT/PriorityWorklist.h"
|
|
|
|
#include "gtest/gtest.h"
|
2017-01-04 19:13:11 +08:00
|
|
|
#include <list>
|
|
|
|
#include <vector>
|
2016-06-30 10:32:20 +08:00
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
template <typename T> class PriorityWorklistTest : public ::testing::Test {};
|
|
|
|
typedef ::testing::Types<PriorityWorklist<int>, SmallPriorityWorklist<int, 2>>
|
|
|
|
TestTypes;
|
2021-05-17 20:12:11 +08:00
|
|
|
TYPED_TEST_SUITE(PriorityWorklistTest, TestTypes, );
|
2016-06-30 10:32:20 +08:00
|
|
|
|
|
|
|
TYPED_TEST(PriorityWorklistTest, Basic) {
|
|
|
|
TypeParam W;
|
|
|
|
EXPECT_TRUE(W.empty());
|
|
|
|
EXPECT_EQ(0u, W.size());
|
|
|
|
EXPECT_FALSE(W.count(42));
|
|
|
|
|
|
|
|
EXPECT_TRUE(W.insert(21));
|
|
|
|
EXPECT_TRUE(W.insert(42));
|
|
|
|
EXPECT_TRUE(W.insert(17));
|
|
|
|
|
|
|
|
EXPECT_FALSE(W.empty());
|
|
|
|
EXPECT_EQ(3u, W.size());
|
|
|
|
EXPECT_TRUE(W.count(42));
|
|
|
|
|
|
|
|
EXPECT_FALSE(W.erase(75));
|
|
|
|
EXPECT_EQ(3u, W.size());
|
|
|
|
EXPECT_EQ(17, W.back());
|
|
|
|
|
|
|
|
EXPECT_TRUE(W.erase(17));
|
|
|
|
EXPECT_FALSE(W.count(17));
|
|
|
|
EXPECT_EQ(2u, W.size());
|
|
|
|
EXPECT_EQ(42, W.back());
|
|
|
|
|
|
|
|
W.clear();
|
|
|
|
EXPECT_TRUE(W.empty());
|
|
|
|
EXPECT_EQ(0u, W.size());
|
|
|
|
|
|
|
|
EXPECT_TRUE(W.insert(21));
|
|
|
|
EXPECT_TRUE(W.insert(42));
|
|
|
|
EXPECT_TRUE(W.insert(12));
|
|
|
|
EXPECT_TRUE(W.insert(17));
|
|
|
|
EXPECT_TRUE(W.count(12));
|
|
|
|
EXPECT_TRUE(W.count(17));
|
|
|
|
EXPECT_EQ(4u, W.size());
|
|
|
|
EXPECT_EQ(17, W.back());
|
|
|
|
EXPECT_TRUE(W.erase(12));
|
|
|
|
EXPECT_FALSE(W.count(12));
|
|
|
|
EXPECT_TRUE(W.count(17));
|
|
|
|
EXPECT_EQ(3u, W.size());
|
|
|
|
EXPECT_EQ(17, W.back());
|
|
|
|
|
|
|
|
EXPECT_FALSE(W.insert(42));
|
|
|
|
EXPECT_EQ(3u, W.size());
|
|
|
|
EXPECT_EQ(42, W.pop_back_val());
|
|
|
|
EXPECT_EQ(17, W.pop_back_val());
|
|
|
|
EXPECT_EQ(21, W.pop_back_val());
|
|
|
|
EXPECT_TRUE(W.empty());
|
|
|
|
}
|
|
|
|
|
2017-01-04 19:13:11 +08:00
|
|
|
TYPED_TEST(PriorityWorklistTest, InsertSequence) {
|
|
|
|
TypeParam W;
|
|
|
|
ASSERT_TRUE(W.insert(2));
|
|
|
|
ASSERT_TRUE(W.insert(4));
|
|
|
|
ASSERT_TRUE(W.insert(7));
|
|
|
|
// Insert a sequence that has internal duplicates and a duplicate among
|
|
|
|
// existing entries.
|
|
|
|
W.insert(std::vector<int>({42, 13, 42, 7, 8}));
|
|
|
|
EXPECT_EQ(8, W.pop_back_val());
|
|
|
|
EXPECT_EQ(7, W.pop_back_val());
|
|
|
|
EXPECT_EQ(42, W.pop_back_val());
|
|
|
|
EXPECT_EQ(13, W.pop_back_val());
|
|
|
|
EXPECT_EQ(4, W.pop_back_val());
|
|
|
|
EXPECT_EQ(2, W.pop_back_val());
|
|
|
|
ASSERT_TRUE(W.empty());
|
|
|
|
|
|
|
|
// Simpler tests with various other input types.
|
|
|
|
ASSERT_TRUE(W.insert(2));
|
|
|
|
ASSERT_TRUE(W.insert(7));
|
|
|
|
// Use a non-random-access container.
|
|
|
|
W.insert(std::list<int>({7, 5}));
|
|
|
|
EXPECT_EQ(5, W.pop_back_val());
|
|
|
|
EXPECT_EQ(7, W.pop_back_val());
|
|
|
|
EXPECT_EQ(2, W.pop_back_val());
|
|
|
|
ASSERT_TRUE(W.empty());
|
|
|
|
|
|
|
|
ASSERT_TRUE(W.insert(2));
|
|
|
|
ASSERT_TRUE(W.insert(7));
|
|
|
|
// Use a raw array.
|
|
|
|
int A[] = {7, 5};
|
|
|
|
W.insert(A);
|
|
|
|
EXPECT_EQ(5, W.pop_back_val());
|
|
|
|
EXPECT_EQ(7, W.pop_back_val());
|
|
|
|
EXPECT_EQ(2, W.pop_back_val());
|
|
|
|
ASSERT_TRUE(W.empty());
|
2017-01-04 19:40:18 +08:00
|
|
|
|
|
|
|
ASSERT_TRUE(W.insert(2));
|
|
|
|
ASSERT_TRUE(W.insert(7));
|
|
|
|
// Inserting an empty sequence does nothing.
|
|
|
|
W.insert(std::vector<int>());
|
|
|
|
EXPECT_EQ(7, W.pop_back_val());
|
|
|
|
EXPECT_EQ(2, W.pop_back_val());
|
|
|
|
ASSERT_TRUE(W.empty());
|
2017-01-04 19:13:11 +08:00
|
|
|
}
|
|
|
|
|
2016-06-30 10:32:20 +08:00
|
|
|
TYPED_TEST(PriorityWorklistTest, EraseIf) {
|
|
|
|
TypeParam W;
|
|
|
|
W.insert(23);
|
|
|
|
W.insert(10);
|
|
|
|
W.insert(47);
|
|
|
|
W.insert(42);
|
|
|
|
W.insert(23);
|
|
|
|
W.insert(13);
|
|
|
|
W.insert(26);
|
|
|
|
W.insert(42);
|
|
|
|
EXPECT_EQ(6u, W.size());
|
|
|
|
|
|
|
|
EXPECT_FALSE(W.erase_if([](int i) { return i > 100; }));
|
|
|
|
EXPECT_EQ(6u, W.size());
|
|
|
|
EXPECT_EQ(42, W.back());
|
|
|
|
|
|
|
|
EXPECT_TRUE(W.erase_if([](int i) {
|
|
|
|
assert(i != 0 && "Saw a null value!");
|
|
|
|
return (i & 1) == 0;
|
|
|
|
}));
|
|
|
|
EXPECT_EQ(3u, W.size());
|
|
|
|
EXPECT_FALSE(W.count(42));
|
|
|
|
EXPECT_FALSE(W.count(26));
|
|
|
|
EXPECT_FALSE(W.count(10));
|
|
|
|
EXPECT_FALSE(W.insert(47));
|
|
|
|
EXPECT_FALSE(W.insert(23));
|
|
|
|
EXPECT_EQ(23, W.pop_back_val());
|
|
|
|
EXPECT_EQ(47, W.pop_back_val());
|
|
|
|
EXPECT_EQ(13, W.pop_back_val());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|