#include #include "BoundedTimeline.h" using namespace testing; using cs = centiseconds; using std::vector; using boost::optional; using std::initializer_list; TEST(BoundedTimeline, constructors_initializeState) { TimeRange range(cs(-5), cs(55)); auto args = { Timed(cs(-10), cs(30), 1), Timed(cs(10), cs(40), 2), Timed(cs(50), cs(60), 3) }; auto expected = { Timed(cs(-5), cs(10), 1), Timed(cs(10), cs(40), 2), Timed(cs(50), cs(55), 3) }; EXPECT_THAT( BoundedTimeline(range, args.begin(), args.end()), ElementsAreArray(expected) ); EXPECT_THAT( BoundedTimeline(range, args), ElementsAreArray(expected) ); } TEST(BoundedTimeline, empty) { BoundedTimeline empty(TimeRange(cs(0), cs(10))); EXPECT_TRUE(empty.empty()); EXPECT_THAT(empty, IsEmpty()); BoundedTimeline nonEmpty(TimeRange(cs(0), cs(10)), { Timed(cs(1), cs(2), 1) }); EXPECT_FALSE(nonEmpty.empty()); EXPECT_THAT(nonEmpty, Not(IsEmpty())); } TEST(BoundedTimeline, getRange) { TimeRange range(cs(0), cs(10)); BoundedTimeline empty(range); EXPECT_EQ(range, empty.getRange()); BoundedTimeline nonEmpty(range, { Timed(cs(1), cs(2), 1) }); EXPECT_EQ(range, nonEmpty.getRange()); } TEST(BoundedTimeline, setAndClear) { TimeRange range(cs(0), cs(10)); BoundedTimeline timeline(range); // Out of range timeline.set(cs(-10), cs(-1), 1); timeline.set(TimeRange(cs(-5), cs(-1)), 2); timeline.set(Timed(cs(10), cs(15), 3)); // Overlapping timeline.set(cs(-2), cs(5), 4); timeline.set(TimeRange(cs(-1), cs(1)), 5); timeline.set(Timed(cs(8), cs(12), 6)); // Within timeline.set(cs(5), cs(9), 7); timeline.set(TimeRange(cs(6), cs(7)), 8); timeline.set(Timed(cs(7), cs(8), 9)); auto expected = { Timed(cs(0), cs(1), 5), Timed(cs(1), cs(5), 4), Timed(cs(5), cs(6), 7), Timed(cs(6), cs(7), 8), Timed(cs(7), cs(8), 9), Timed(cs(8), cs(9), 7), Timed(cs(9), cs(10), 6) }; EXPECT_THAT(timeline, ElementsAreArray(expected)); } TEST(BoundedTimeline, shift) { BoundedTimeline timeline(TimeRange(cs(0), cs(10)), { { cs(1), cs(2), 1 }, { cs(2), cs(5), 2 }, { cs(7), cs(9), 3 } }); BoundedTimeline expected(TimeRange(cs(2), cs(12)), { { cs(3), cs(4), 1 }, { cs(4), cs(7), 2 }, { cs(9), cs(11), 3 } }); timeline.shift(cs(2)); EXPECT_EQ(expected, timeline); } TEST(BoundedTimeline, equality) { vector> timelines = { BoundedTimeline(TimeRange(cs(0), cs(10))), BoundedTimeline(TimeRange(cs(0), cs(10)), { { cs(1), cs(2), 1 } }), BoundedTimeline(TimeRange(cs(1), cs(10)), { { cs(1), cs(2), 1 } }) }; for (size_t i = 0; i < timelines.size(); ++i) { for (size_t j = 0; j < timelines.size(); ++j) { if (i == j) { EXPECT_EQ(timelines[i], BoundedTimeline(timelines[j])) << "i: " << i << ", j: " << j; } else { EXPECT_NE(timelines[i], timelines[j]) << "i: " << i << ", j: " << j; } } } }