#include "interval_set.h"
#include "gtest/gtest.h"
using namespace __orc_rt;
TEST(IntervalSetTest, DefaultConstructed) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
EXPECT_TRUE(S.empty());
EXPECT_TRUE(S.begin() == S.end());
EXPECT_TRUE(S.find(0) == S.end());
}
TEST(IntervalSetTest, InsertSingleElement) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 8);
EXPECT_FALSE(S.empty());
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.find(7), S.begin());
EXPECT_EQ(S.find(8), S.end());
}
TEST(IntervalSetTest, InsertCoalesceWithPrevious) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 8);
S.insert(8, 9);
EXPECT_FALSE(S.empty());
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.find(7), S.find(8));
}
TEST(IntervalSetTest, InsertCoalesceWithFollowing) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(8, 9);
S.insert(7, 8);
EXPECT_FALSE(S.empty());
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.find(7), S.find(8));
}
TEST(IntervalSetTest, InsertCoalesceBoth) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 8);
S.insert(9, 10);
EXPECT_NE(S.find(7), S.find(9));
S.insert(8, 9);
EXPECT_FALSE(S.empty());
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.find(7), S.find(8));
EXPECT_EQ(S.find(8), S.find(9));
}
TEST(IntervalSetTest, EraseSplittingLeft) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 10);
EXPECT_FALSE(S.empty());
S.erase(9, 10);
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.begin()->first, 7U);
EXPECT_EQ(S.begin()->second, 9U);
}
TEST(IntervalSetTest, EraseSplittingRight) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 10);
EXPECT_FALSE(S.empty());
S.erase(7, 8);
EXPECT_EQ(std::next(S.begin()), S.end());
EXPECT_EQ(S.begin()->first, 8U);
EXPECT_EQ(S.begin()->second, 10U);
}
TEST(IntervalSetTest, EraseSplittingBoth) {
IntervalSet<unsigned, IntervalCoalescing::Enabled> S;
S.insert(7, 10);
EXPECT_FALSE(S.empty());
S.erase(8, 9);
EXPECT_EQ(std::next(std::next(S.begin())), S.end());
EXPECT_EQ(S.begin()->first, 7U);
EXPECT_EQ(S.begin()->second, 8U);
EXPECT_EQ(std::next(S.begin())->first, 9U);
EXPECT_EQ(std::next(S.begin())->second, 10U);
}