| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | 
//              Copyright Catch2 Authors// Distributed under the Boost Software License, Version 1.0.//   (See accompanying file LICENSE_1_0.txt or copy at//        https://www.boost.org/LICENSE_1_0.txt)// SPDX-License-Identifier: BSL-1.0#define CATCH_CONFIG_ENABLE_VARIANT_STRINGMAKER#include <catch2/catch_test_macros.hpp>#if defined(CATCH_CONFIG_CPP17_VARIANT)#include <string>#include <variant>// We need 2 types with non-trivial copies/movesstruct MyType1 {    MyType1() = default;    [[noreturn]] MyType1(MyType1 const&) { throw 1; }    MyType1& operator=(MyType1 const&) { throw 3; }};struct MyType2 {    MyType2() = default;    [[noreturn]] MyType2(MyType2 const&) { throw 2; }    MyType2& operator=(MyType2 const&) { throw 4; }};TEST_CASE( "variant<std::monostate>", "[toString][variant][approvals]"){    using type = std::variant<std::monostate>;    CHECK( "{ }" == ::Catch::Detail::stringify(type{}) );    type value {};    CHECK( "{ }" == ::Catch::Detail::stringify(value) );    CHECK( "{ }" == ::Catch::Detail::stringify(std::get<0>(value)) );}TEST_CASE( "variant<int>", "[toString][variant][approvals]"){    using type = std::variant<int>;    CHECK( "0" == ::Catch::Detail::stringify(type{0}) );}TEST_CASE( "variant<float, int>", "[toString][variant][approvals]"){    using type = std::variant<float, int>;    CHECK( "0.5f" == ::Catch::Detail::stringify(type{0.5f}) );    CHECK( "0" == ::Catch::Detail::stringify(type{0}) );}TEST_CASE( "variant -- valueless-by-exception", "[toString][variant][approvals]" ) {    using type = std::variant<MyType1, MyType2>;    type value;    REQUIRE_THROWS_AS(value.emplace<MyType2>(MyType2{}), int);    REQUIRE(value.valueless_by_exception());    CHECK("{valueless variant}" == ::Catch::Detail::stringify(value));}TEST_CASE( "variant<string, int>", "[toString][variant][approvals]"){    using type = std::variant<std::string, int>;    CHECK( "\"foo\"" == ::Catch::Detail::stringify(type{"foo"}) );    CHECK( "0" == ::Catch::Detail::stringify(type{0}) );}TEST_CASE( "variant<variant<float, int>, string>", "[toString][variant][approvals]"){    using inner = std::variant<MyType1, float, int>;    using type = std::variant<inner, std::string>;    CHECK( "0.5f" == ::Catch::Detail::stringify(type{0.5f}) );    CHECK( "0" == ::Catch::Detail::stringify(type{0}) );    CHECK( "\"foo\"" == ::Catch::Detail::stringify(type{"foo"}) );    SECTION("valueless nested variant") {        type value = inner{0.5f};        REQUIRE( std::holds_alternative<inner>(value) );        REQUIRE( std::holds_alternative<float>(std::get<inner>(value)) );        REQUIRE_THROWS_AS( std::get<0>(value).emplace<MyType1>(MyType1{}), int );        // outer variant is still valid and contains inner        REQUIRE( std::holds_alternative<inner>(value) );        // inner variant is valueless        REQUIRE( std::get<inner>(value).valueless_by_exception() );        CHECK( "{valueless variant}" == ::Catch::Detail::stringify(value) );    }}TEST_CASE( "variant<nullptr,int,const char *>", "[toString][variant][approvals]" ){    using type = std::variant<std::nullptr_t,int,const char *>;    CHECK( "nullptr" == ::Catch::Detail::stringify(type{nullptr}) );    CHECK( "42" == ::Catch::Detail::stringify(type{42}) );    CHECK( "\"Catch me\"" == ::Catch::Detail::stringify(type{"Catch me"}) );}#endif // CATCH_INTERNAL_CONFIG_CPP17_VARIANT
 |