#include "iterator/join_iterator.hpp" #include #include "xcode_gtest_helper.h" using iterator::end_aware_iterator; using iterator::joining_iterator; using testing::Ne; TEST(JoinIteratorTest, FirstDereferencedElemIsTheFirstInTheChain) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; EXPECT_THAT(*joining_iterator(mv), mv[0][0]); } TEST(JoinIteratorTest, HoldsReferenceToContainedElements) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; EXPECT_THAT(joining_iterator(mv).operator->(), &mv[0][0]); } TEST(JoinIteratorTest, DefaultCtorIsEnd) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); EXPECT_THAT(it, Ne(decltype(it)())); mv.clear(); EXPECT_THAT(joining_iterator(mv), decltype(it)()); } // TODO: This ought to be implemented as a compiles-test TEST(JoinIteratorTest, CanCastCompatibleIterators) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); iterator::joining_iterator{it}; } TEST(JoinIteratorTest, CanAccessInternalIterator) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; auto eai = end_aware_iterator(mv); joining_iterator it(eai); EXPECT_THAT(it.join_iterator(), eai); } TEST(JoinIteratorTest, CanAccessChildIterator) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); EXPECT_THAT(it.element_iterator(), end_aware_iterator(mv[0])); } TEST(JoinIteratorTest, PreIncrementAdvancesIterator) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); EXPECT_THAT(*it, 1); EXPECT_THAT(*++it, 2); EXPECT_THAT(*it, 2); } TEST(JoinIteratorTest, PostIncrementReturnsCopyOfPrev) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); EXPECT_THAT(*it, 1); EXPECT_THAT(*it++, 1); EXPECT_THAT(*it, 2); } TEST(JoinIteratorTest, MovesFromListToListWhenReachingEnd) { std::vector> mv{{1, 2, 3}, {4, 5, 6}}; joining_iterator it(mv); std::advance(it, 2); EXPECT_THAT(*++it, mv[1][0]); } TEST(JoinIteratorTest, SkipsOverEmptyElements) { std::vector> mv{{1, 2, 3}, {}, {4, 5, 6}}; joining_iterator it(mv); std::advance(it, 2); EXPECT_THAT(*++it, mv[2][0]); }