1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
|
//===-- flang/unittests/Common/FastIntSetTest.cpp ---------------*- C++ -*-===//
//
// 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
//
//===----------------------------------------------------------------------===//
#include "gtest/gtest.h"
#include "flang/Common/fast-int-set.h"
#include <optional>
TEST(FastIntSetTests, Sanity) {
static constexpr int N{100};
Fortran::common::FastIntSet<N> set;
ASSERT_FALSE(set.IsValidValue(-1));
ASSERT_TRUE(set.IsValidValue(0));
ASSERT_TRUE(set.IsValidValue(N - 1));
ASSERT_FALSE(set.IsValidValue(N));
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
ASSERT_FALSE(set.Contains(0));
ASSERT_FALSE(set.Contains(N - 1));
ASSERT_TRUE(set.Add(0));
ASSERT_FALSE(set.IsEmpty());
ASSERT_EQ(set.size(), 1);
ASSERT_TRUE(set.Contains(0));
ASSERT_TRUE(set.Add(0)); // duplicate
ASSERT_EQ(set.size(), 1);
ASSERT_TRUE(set.Contains(0));
ASSERT_TRUE(set.Remove(0));
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
ASSERT_FALSE(set.Contains(0));
ASSERT_FALSE(set.Add(N));
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
ASSERT_FALSE(set.Contains(N));
ASSERT_TRUE(set.Add(N - 1));
ASSERT_FALSE(set.IsEmpty());
ASSERT_EQ(set.size(), 1);
ASSERT_TRUE(set.Contains(N - 1));
std::optional<int> x;
x = set.PopValue();
ASSERT_TRUE(x.has_value());
ASSERT_EQ(*x, N - 1);
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
x = set.PopValue();
ASSERT_FALSE(x.has_value());
for (int j{0}; j < N; ++j) {
ASSERT_TRUE(set.Add(j)) << j;
}
ASSERT_FALSE(set.IsEmpty());
ASSERT_EQ(set.size(), N);
for (int j{0}; j < N; ++j) {
ASSERT_TRUE(set.Contains(j)) << j;
}
for (int j{0}; j < N; ++j) {
ASSERT_TRUE(set.Remove(j)) << j;
ASSERT_EQ(set.size(), N - j - 1) << j;
ASSERT_FALSE(set.Contains(j)) << j;
}
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
for (int j{N - 1}; j >= 0; --j) {
ASSERT_TRUE(set.Add(j)) << j;
}
for (int j{0}; j < N; j++) {
x = set.PopValue();
ASSERT_TRUE(x.has_value());
ASSERT_EQ(*x, j) << j;
}
ASSERT_TRUE(set.IsEmpty());
ASSERT_EQ(set.size(), 0);
for (int j{0}; j < N; j++) {
ASSERT_TRUE(set.Add(j)) << j;
}
ASSERT_FALSE(set.IsEmpty());
ASSERT_EQ(set.size(), N);
for (int j{0}; j < N; j += 2) {
ASSERT_TRUE(set.Remove(j)) << j;
}
ASSERT_FALSE(set.IsEmpty());
ASSERT_EQ(set.size(), N / 2);
for (int j{0}; j < N; j++) {
ASSERT_EQ(set.Contains(j), (j & 1) == 1);
}
set.Clear();
ASSERT_TRUE(set.IsEmpty());
}
|