// // immer: immutable data structures for C++ // Copyright (C) 2016, 2017, 2018 Juan Pedro Bolivar Puente // // This software is distributed under the Boost Software License, Version 1.0. // See accompanying file LICENSE or copy at http://boost.org/LICENSE_1_0.txt // #include #include #include #include #include struct string_sentinel {}; bool operator==(const char* i, string_sentinel); bool operator!=(const char* i, string_sentinel); TEST_CASE("compatible_sentinel_v") { SECTION("iterator pairs") { using Iter = std::vector::iterator; static_assert(immer::detail::compatible_sentinel_v, ""); } SECTION("pointer pairs") { using Iter = char*; static_assert(immer::detail::compatible_sentinel_v, ""); } SECTION("iterator/sentinel pair") { using Iter = char*; using Sent = string_sentinel; static_assert(immer::detail::compatible_sentinel_v, ""); } SECTION("incompatible pair") { using Iter1 = std::vector::iterator; using Iter2 = std::list::iterator; static_assert(not immer::detail::compatible_sentinel_v, ""); } } TEST_CASE("equality comparable") { SECTION("iterator pairs") { using Iter = std::vector::iterator; static_assert(immer::detail::is_equality_comparable_v, ""); } SECTION("pointer pairs") { using Iter = char*; static_assert(immer::detail::is_equality_comparable_v, ""); } SECTION("iterator/sentinel pair") { using Iter = char*; using Sent = string_sentinel; static_assert(immer::detail::is_equality_comparable_v, ""); } SECTION("not equality comparable") { static_assert( not immer::detail::is_equality_comparable_v, ""); } } TEST_CASE("inequality comparable") { SECTION("iterator pairs") { using Iter = std::vector::iterator; static_assert(immer::detail::is_inequality_comparable_v, ""); } SECTION("pointer pairs") { using Iter = char*; static_assert(immer::detail::is_inequality_comparable_v, ""); } SECTION("iterator/sentinel pair") { using Iter = char*; using Sent = string_sentinel; static_assert(immer::detail::is_inequality_comparable_v, ""); } SECTION("not inequality comparable") { static_assert( not immer::detail::is_inequality_comparable_v, ""); } } TEST_CASE("is dereferenceable") { SECTION("iterator") { using Iter = std::vector::iterator; static_assert(immer::detail::is_dereferenceable_v, ""); } SECTION("pointer") { using Iter = char*; static_assert(immer::detail::is_dereferenceable_v, ""); } SECTION("not dereferenceable") { static_assert(not immer::detail::is_dereferenceable_v, ""); } } TEST_CASE("is forward iterator") { SECTION("random access iterator") { using Iter = std::vector::iterator; static_assert(immer::detail::is_forward_iterator_v, ""); } SECTION("bidirectional iterator") { using Iter = std::list::iterator; static_assert(immer::detail::is_forward_iterator_v, ""); } SECTION("forward iterator") { using Iter = std::forward_list::iterator; static_assert(immer::detail::is_forward_iterator_v, ""); } SECTION("input iterator") { using Iter = std::istream_iterator; static_assert(not immer::detail::is_forward_iterator_v, ""); } SECTION("output iterator") { using Iter = std::ostream_iterator; static_assert(not immer::detail::is_forward_iterator_v, ""); } SECTION("pointer") { using Iter = char*; static_assert(immer::detail::is_forward_iterator_v, ""); } } TEST_CASE("is iterator") { SECTION("iterator") { using Iter = std::vector::iterator; static_assert(immer::detail::is_iterator_v, ""); } SECTION("pointer") { using Iter = char*; static_assert(immer::detail::is_iterator_v, ""); } SECTION("not iterator") { static_assert(not immer::detail::is_iterator_v, ""); } } TEST_CASE("provides preincrement") { SECTION("iterator") { using Iter = std::vector::iterator; static_assert(immer::detail::is_preincrementable_v, ""); } SECTION("pointer") { using Iter = char*; static_assert(immer::detail::is_preincrementable_v, ""); } SECTION("does not provide preincrement") { struct type {}; static_assert(not immer::detail::is_preincrementable_v, ""); } } TEST_CASE("void_t") { static_assert(std::is_same>::value, ""); }