File: ToStringWhich.cpp

package info (click to toggle)
wxpython4.0 4.2.3%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 221,752 kB
  • sloc: cpp: 962,555; python: 230,573; ansic: 170,731; makefile: 51,756; sh: 9,342; perl: 1,564; javascript: 584; php: 326; xml: 200
file content (71 lines) | stat: -rw-r--r-- 2,261 bytes parent folder | download | duplicates (14)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include "catch.hpp"
/*
    Demonstrate which version of toString/StringMaker is being used
    for various types
*/


struct has_toString { };
struct has_maker {};
struct has_maker_and_toString {};

namespace Catch {
    inline std::string toString( const has_toString& ) {
        return "toString( has_toString )";
    }
    inline std::string toString( const has_maker_and_toString& ) {
        return "toString( has_maker_and_toString )";
    }
    template<>
    struct StringMaker<has_maker> {
        static std::string convert( const has_maker& ) {
            return "StringMaker<has_maker>";
        }
    };
    template<>
    struct StringMaker<has_maker_and_toString> {
        static std::string convert( const has_maker_and_toString& ) {
            return "StringMaker<has_maker_and_toString>";
        }
    };
}

// Call the overload
TEST_CASE( "toString( has_toString )", "[toString]" ) {
    has_toString item;
    REQUIRE( Catch::toString( item ) == "toString( has_toString )" );
}

// Call the overload
TEST_CASE( "toString( has_maker )", "toString]" ) {
    has_maker item;
    REQUIRE( Catch::toString( item ) == "StringMaker<has_maker>" );
}

// Call the overload
TEST_CASE( "toString( has_maker_and_toString )", "[.][toString]" ) {
    has_maker_and_toString item;
    REQUIRE( Catch::toString( item ) == "toString( has_maker_and_toString )" );
}

// Vectors...

// Don't run this in approval tests as it is sensitive to two phase lookup differences
TEST_CASE( "toString( vectors<has_toString )", "[.][toString][!nonportable]" ) {
    std::vector<has_toString> v(1);
    // This invokes template<T> toString which actually gives us '{ ? }'
    REQUIRE( Catch::toString( v ) == "{ {?} }" );
}

TEST_CASE( "toString( vectors<has_maker )", "[toString]" ) {
    std::vector<has_maker> v(1);
    REQUIRE( Catch::toString( v ) == "{ StringMaker<has_maker> }" );
}


// Don't run this in approval tests as it is sensitive to two phase lookup differences
TEST_CASE( "toString( vectors<has_maker_and_toString )", "[.][toString][!nonportable]" ) {
    std::vector<has_maker_and_toString> v(1);
    // Note: This invokes the template<T> toString -> StringMaker
    REQUIRE( Catch::toString( v ) == "{ StringMaker<has_maker_and_toString> }" );
}