join_iterator_test.cxx 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. #include "iterator/join_iterator.hpp"
  2. #include <vector>
  3. #include "xcode_gtest_helper.h"
  4. using iterator::end_aware_iterator;
  5. using iterator::joining_iterator;
  6. using testing::Ne;
  7. TEST(JoinIteratorTest, FirstDereferencedElemIsTheFirstInTheChain) {
  8. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  9. EXPECT_THAT(*joining_iterator(mv), mv[0][0]);
  10. }
  11. TEST(JoinIteratorTest, HoldsReferenceToContainedElements) {
  12. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  13. EXPECT_THAT(joining_iterator(mv).operator->(), &mv[0][0]);
  14. }
  15. TEST(JoinIteratorTest, DefaultCtorIsEnd) {
  16. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  17. joining_iterator it(mv);
  18. EXPECT_THAT(it, Ne(decltype(it)()));
  19. mv.clear();
  20. EXPECT_THAT(joining_iterator(mv), decltype(it)());
  21. }
  22. // TODO: This ought to be implemented as a compiles-test
  23. TEST(JoinIteratorTest, CanCastCompatibleIterators) {
  24. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  25. joining_iterator it(mv);
  26. iterator::joining_iterator<decltype(mv)::const_iterator>{it};
  27. }
  28. TEST(JoinIteratorTest, CanAccessInternalIterator) {
  29. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  30. auto eai = end_aware_iterator(mv);
  31. joining_iterator it(eai);
  32. EXPECT_THAT(it.join_iterator(), eai);
  33. }
  34. TEST(JoinIteratorTest, CanAccessChildIterator) {
  35. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  36. joining_iterator it(mv);
  37. EXPECT_THAT(it.element_iterator(), end_aware_iterator(mv[0]));
  38. }
  39. TEST(JoinIteratorTest, EmptyConstructorEqualsEnd) {
  40. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  41. joining_iterator it(end_aware_iterator(mv.end(), mv.end()),
  42. end_aware_iterator(mv.back().end(), mv.back().end()));
  43. EXPECT_THAT(it, decltype(it)());
  44. }
  45. TEST(JoinIteratorTest, PreIncrementAdvancesIterator) {
  46. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  47. joining_iterator it(mv);
  48. EXPECT_THAT(*it, 1);
  49. EXPECT_THAT(*++it, 2);
  50. EXPECT_THAT(*it, 2);
  51. }
  52. TEST(JoinIteratorTest, PostIncrementReturnsCopyOfPrev) {
  53. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  54. joining_iterator it(mv);
  55. EXPECT_THAT(*it, 1);
  56. EXPECT_THAT(*it++, 1);
  57. EXPECT_THAT(*it, 2);
  58. }
  59. TEST(JoinIteratorTest, MovesFromListToListWhenReachingEnd) {
  60. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  61. joining_iterator it(mv);
  62. std::advance(it, 3);
  63. EXPECT_THAT(*++it, mv[1][0]);
  64. }
  65. TEST(JoinIteratorTest, SkipsOverEmptyElements) {
  66. std::vector<std::vector<int>> mv{{1, 2, 3}, {}, {4, 5, 6}};
  67. joining_iterator it(mv);
  68. std::advance(it, 3);
  69. EXPECT_THAT(*++it, mv[2][0]);
  70. }
  71. TEST(JoinIteratorTest, IncrementEndIsUnsafe) {
  72. std::vector<std::vector<int>> mv{{1, 2, 3}, {4, 5, 6}};
  73. joining_iterator it(end_aware_iterator(mv.end(), mv.end()),
  74. end_aware_iterator(mv.back().end(), mv.back().end()));
  75. joining_iterator const cp = it;
  76. ++it;
  77. EXPECT_NE(it, cp);
  78. }