Misc.tests.cpp:: passed: with 1 message: 'yay' Decomposition.tests.cpp:: passed: fptr == 0 for: 0 == 0 Decomposition.tests.cpp:: passed: fptr == 0l for: 0 == 0 Compilation.tests.cpp:: passed: y.v == 0 for: 0 == 0 Compilation.tests.cpp:: passed: 0 == y.v for: 0 == 0 Compilation.tests.cpp:: passed: y.v == 0 for: 0 == 0 Compilation.tests.cpp:: passed: 0 == y.v for: 0 == 0 Compilation.tests.cpp:: passed: t1 == t2 for: {?} == {?} Compilation.tests.cpp:: passed: t1 != t2 for: {?} != {?} Compilation.tests.cpp:: passed: t1 < t2 for: {?} < {?} Compilation.tests.cpp:: passed: t1 > t2 for: {?} > {?} Compilation.tests.cpp:: passed: t1 <= t2 for: {?} <= {?} Compilation.tests.cpp:: passed: t1 >= t2 for: {?} >= {?} Misc.tests.cpp:: passed: Compilation.tests.cpp:: passed: std::memcmp(uarr, "123", sizeof(uarr)) == 0 for: 0 == 0 with 2 messages: 'uarr := "123"' and 'sarr := "456"' Compilation.tests.cpp:: passed: std::memcmp(sarr, "456", sizeof(sarr)) == 0 for: 0 == 0 with 2 messages: 'uarr := "123"' and 'sarr := "456"' Compilation.tests.cpp:: passed: Compilation.tests.cpp:: passed: Compilation.tests.cpp:: passed: h1 == h2 for: [1403 helper] == [1403 helper] Message.tests.cpp:: warning: ' This info message starts with a linebreak' with 1 message: ' This warning message starts with a linebreak' This would not be caught previously Nor would this Tricky.tests.cpp:: failed: explicitly with 1 message: '1514' Compilation.tests.cpp:: passed: std::is_same, TypeList>::value for: true Exception.tests.cpp:: failed: unexpected exception with message: 'answer := 42' with 1 message: 'expected exception' Exception.tests.cpp:: failed: unexpected exception with message: 'answer := 42'; expression was: thisThrows() with 1 message: 'expected exception' Exception.tests.cpp:: passed: thisThrows() with 1 message: 'answer := 42' Compilation.tests.cpp:: passed: 42 == f for: 42 == {?} Compilation.tests.cpp:: passed: a == t for: 3 == 3 Compilation.tests.cpp:: passed: a == t for: 3 == 3 Compilation.tests.cpp:: passed: throws_int(true) Compilation.tests.cpp:: passed: throws_int(true), int Compilation.tests.cpp:: passed: throws_int(false) Compilation.tests.cpp:: passed: "aaa", Catch::EndsWith("aaa") for: "aaa" ends with: "aaa" Compilation.tests.cpp:: passed: templated_tests(3) for: true Misc.tests.cpp:: failed: f() == 0 for: 1 == 0 Misc.tests.cpp:: passed: errno == 1 for: 1 == 1 Compilation.tests.cpp:: passed: x == 4 for: {?} == 4 with 1 message: 'dummy := 0' Misc.tests.cpp:: passed: with 1 message: 'Everything is OK' Misc.tests.cpp:: passed: with 1 message: 'Everything is OK' Misc.tests.cpp:: passed: with 1 message: 'Everything is OK' Misc.tests.cpp:: passed: with 1 message: 'Everything is OK' Misc.tests.cpp:: passed: with 1 message: 'Everything is OK' Condition.tests.cpp:: failed: false != false Condition.tests.cpp:: failed: true != true Condition.tests.cpp:: failed: !true for: false Condition.tests.cpp:: failed: !(true) for: !true Condition.tests.cpp:: failed: !trueValue for: false Condition.tests.cpp:: failed: !(trueValue) for: !true Condition.tests.cpp:: failed: !(1 == 1) for: false Condition.tests.cpp:: failed: !(1 == 1) Condition.tests.cpp:: passed: false == false Condition.tests.cpp:: passed: true == true Condition.tests.cpp:: passed: !false for: true Condition.tests.cpp:: passed: !(false) for: !false Condition.tests.cpp:: passed: !falseValue for: true Condition.tests.cpp:: passed: !(falseValue) for: !false Condition.tests.cpp:: passed: !(1 == 2) for: true Condition.tests.cpp:: passed: !(1 == 2) Tricky.tests.cpp:: passed: is_true::value == true for: true == true Tricky.tests.cpp:: passed: true == is_true::value for: true == true Tricky.tests.cpp:: passed: is_true::value == false for: false == false Tricky.tests.cpp:: passed: false == is_true::value for: false == false Tricky.tests.cpp:: passed: !is_true::value for: true Tricky.tests.cpp:: passed: !!is_true::value for: true Tricky.tests.cpp:: passed: is_true::value for: true Tricky.tests.cpp:: passed: !(is_true::value) for: !false Generators.tests.cpp:: passed: x < y for: 1 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 7 Generators.tests.cpp:: passed: x < z for: 1 < 7 Generators.tests.cpp:: passed: x < y for: 1 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 8 Generators.tests.cpp:: passed: x < z for: 1 < 8 Generators.tests.cpp:: passed: x < y for: 1 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 9 Generators.tests.cpp:: passed: x < z for: 1 < 9 Generators.tests.cpp:: passed: x < y for: 1 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 7 Generators.tests.cpp:: passed: x < z for: 1 < 7 Generators.tests.cpp:: passed: x < y for: 1 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 8 Generators.tests.cpp:: passed: x < z for: 1 < 8 Generators.tests.cpp:: passed: x < y for: 1 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 9 Generators.tests.cpp:: passed: x < z for: 1 < 9 Generators.tests.cpp:: passed: x < y for: 1 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 7 Generators.tests.cpp:: passed: x < z for: 1 < 7 Generators.tests.cpp:: passed: x < y for: 1 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 8 Generators.tests.cpp:: passed: x < z for: 1 < 8 Generators.tests.cpp:: passed: x < y for: 1 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 9 Generators.tests.cpp:: passed: x < z for: 1 < 9 Generators.tests.cpp:: passed: x < y for: 2 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 7 Generators.tests.cpp:: passed: x < z for: 2 < 7 Generators.tests.cpp:: passed: x < y for: 2 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 8 Generators.tests.cpp:: passed: x < z for: 2 < 8 Generators.tests.cpp:: passed: x < y for: 2 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 9 Generators.tests.cpp:: passed: x < z for: 2 < 9 Generators.tests.cpp:: passed: x < y for: 2 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 7 Generators.tests.cpp:: passed: x < z for: 2 < 7 Generators.tests.cpp:: passed: x < y for: 2 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 8 Generators.tests.cpp:: passed: x < z for: 2 < 8 Generators.tests.cpp:: passed: x < y for: 2 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 9 Generators.tests.cpp:: passed: x < z for: 2 < 9 Generators.tests.cpp:: passed: x < y for: 2 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 7 Generators.tests.cpp:: passed: x < z for: 2 < 7 Generators.tests.cpp:: passed: x < y for: 2 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 8 Generators.tests.cpp:: passed: x < z for: 2 < 8 Generators.tests.cpp:: passed: x < y for: 2 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 9 Generators.tests.cpp:: passed: x < z for: 2 < 9 Generators.tests.cpp:: passed: x < y for: 3 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 7 Generators.tests.cpp:: passed: x < z for: 3 < 7 Generators.tests.cpp:: passed: x < y for: 3 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 8 Generators.tests.cpp:: passed: x < z for: 3 < 8 Generators.tests.cpp:: passed: x < y for: 3 < 4 Generators.tests.cpp:: passed: y < z for: 4 < 9 Generators.tests.cpp:: passed: x < z for: 3 < 9 Generators.tests.cpp:: passed: x < y for: 3 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 7 Generators.tests.cpp:: passed: x < z for: 3 < 7 Generators.tests.cpp:: passed: x < y for: 3 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 8 Generators.tests.cpp:: passed: x < z for: 3 < 8 Generators.tests.cpp:: passed: x < y for: 3 < 5 Generators.tests.cpp:: passed: y < z for: 5 < 9 Generators.tests.cpp:: passed: x < z for: 3 < 9 Generators.tests.cpp:: passed: x < y for: 3 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 7 Generators.tests.cpp:: passed: x < z for: 3 < 7 Generators.tests.cpp:: passed: x < y for: 3 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 8 Generators.tests.cpp:: passed: x < z for: 3 < 8 Generators.tests.cpp:: passed: x < y for: 3 < 6 Generators.tests.cpp:: passed: y < z for: 6 < 9 Generators.tests.cpp:: passed: x < z for: 3 < 9 Class.tests.cpp:: failed: s == "world" for: "hello" == "world" Class.tests.cpp:: passed: s == "hello" for: "hello" == "hello" Class.tests.cpp:: failed: Template_Fixture_2::m_a.size() == 1 for: 0 == 1 Class.tests.cpp:: failed: Template_Fixture_2::m_a.size() == 1 for: 0 == 1 Class.tests.cpp:: failed: Template_Fixture_2::m_a.size() == 1 for: 0 == 1 Class.tests.cpp:: failed: Template_Fixture_2::m_a.size() == 1 for: 0 == 1 Class.tests.cpp:: passed: Template_Fixture_2::m_a.size() == 0 for: 0 == 0 Class.tests.cpp:: passed: Template_Fixture_2::m_a.size() == 0 for: 0 == 0 Class.tests.cpp:: passed: Template_Fixture_2::m_a.size() == 0 for: 0 == 0 Class.tests.cpp:: passed: Template_Fixture_2::m_a.size() == 0 for: 0 == 0 Class.tests.cpp:: failed: Template_Fixture_2{}.m_a.size() < 2 for: 6 < 2 Class.tests.cpp:: failed: Template_Fixture_2{}.m_a.size() < 2 for: 2 < 2 Class.tests.cpp:: failed: Template_Fixture_2{}.m_a.size() < 2 for: 6 < 2 Class.tests.cpp:: failed: Template_Fixture_2{}.m_a.size() < 2 for: 2 < 2 Class.tests.cpp:: passed: Template_Fixture_2{}.m_a.size() >= 2 for: 6 >= 2 Class.tests.cpp:: passed: Template_Fixture_2{}.m_a.size() >= 2 for: 2 >= 2 Class.tests.cpp:: passed: Template_Fixture_2{}.m_a.size() >= 2 for: 6 >= 2 Class.tests.cpp:: passed: Template_Fixture_2{}.m_a.size() >= 2 for: 2 >= 2 Class.tests.cpp:: failed: Template_Fixture::m_a == 2 for: 1.0 == 2 Class.tests.cpp:: failed: Template_Fixture::m_a == 2 for: 1.0f == 2 Class.tests.cpp:: failed: Template_Fixture::m_a == 2 for: 1 == 2 Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1.0 == 1 Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1.0f == 1 Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1 == 1 Class.tests.cpp:: failed: Nttp_Fixture::value == 0 for: 1 == 0 Class.tests.cpp:: failed: Nttp_Fixture::value == 0 for: 3 == 0 Class.tests.cpp:: failed: Nttp_Fixture::value == 0 for: 6 == 0 Class.tests.cpp:: passed: Nttp_Fixture::value > 0 for: 1 > 0 Class.tests.cpp:: passed: Nttp_Fixture::value > 0 for: 3 > 0 Class.tests.cpp:: passed: Nttp_Fixture::value > 0 for: 6 > 0 Class.tests.cpp:: failed: m_a == 2 for: 1 == 2 Class.tests.cpp:: passed: m_a == 1 for: 1 == 1 Misc.tests.cpp:: passed: x.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: x.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: x.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: x.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: x.size() > 0 for: 42 > 0 Misc.tests.cpp:: passed: x.size() > 0 for: 9 > 0 Misc.tests.cpp:: passed: x.size() > 0 for: 42 > 0 Misc.tests.cpp:: passed: x.size() > 0 for: 9 > 0 Approx.tests.cpp:: passed: d == 1.23_a for: 1.23 == Approx( 1.23 ) Approx.tests.cpp:: passed: d != 1.22_a for: 1.23 != Approx( 1.22 ) Approx.tests.cpp:: passed: -d == -1.23_a for: -1.23 == Approx( -1.23 ) Approx.tests.cpp:: passed: d == 1.2_a .epsilon(.1) for: 1.23 == Approx( 1.2 ) Approx.tests.cpp:: passed: d != 1.2_a .epsilon(.001) for: 1.23 != Approx( 1.2 ) Approx.tests.cpp:: passed: d == 1_a .epsilon(.3) for: 1.23 == Approx( 1.0 ) Misc.tests.cpp:: passed: with 1 message: 'that's not flying - that's failing in style' Misc.tests.cpp:: failed: explicitly with 1 message: 'to infinity and beyond' Tricky.tests.cpp:: failed: &o1 == &o2 for: 0x == 0x Tricky.tests.cpp:: failed: o1 == o2 for: {?} == {?} Approx.tests.cpp:: passed: 104.0 != Approx(100.0) for: 104.0 != Approx( 100.0 ) Approx.tests.cpp:: passed: 104.0 == Approx(100.0).margin(5) for: 104.0 == Approx( 100.0 ) Approx.tests.cpp:: passed: 104.0 == Approx(100.0).margin(4) for: 104.0 == Approx( 100.0 ) Approx.tests.cpp:: passed: 104.0 != Approx(100.0).margin(3) for: 104.0 != Approx( 100.0 ) Approx.tests.cpp:: passed: 100.3 != Approx(100.0) for: 100.3 != Approx( 100.0 ) Approx.tests.cpp:: passed: 100.3 == Approx(100.0).margin(0.5) for: 100.3 == Approx( 100.0 ) Tricky.tests.cpp:: passed: i++ == 7 for: 7 == 7 Tricky.tests.cpp:: passed: i++ == 8 for: 8 == 8 Exception.tests.cpp:: passed: 1 == 1 Exception.tests.cpp:: failed: unexpected exception with message: 'unexpected exception'; expression was: {Unknown expression after the reported line} VariadicMacros.tests.cpp:: passed: with 1 message: 'anonymous test case' Approx.tests.cpp:: passed: Approx(0).margin(0) Approx.tests.cpp:: passed: Approx(0).margin(1234656) Approx.tests.cpp:: passed: Approx(0).margin(-2), std::domain_error Approx.tests.cpp:: passed: Approx(0).epsilon(0) Approx.tests.cpp:: passed: Approx(0).epsilon(1) Approx.tests.cpp:: passed: Approx(0).epsilon(-0.001), std::domain_error Approx.tests.cpp:: passed: Approx(0).epsilon(1.0001), std::domain_error Approx.tests.cpp:: passed: 0.25f == Approx(0.0f).margin(0.25f) for: 0.25f == Approx( 0.0 ) Approx.tests.cpp:: passed: 0.0f == Approx(0.25f).margin(0.25f) for: 0.0f == Approx( 0.25 ) Approx.tests.cpp:: passed: 0.5f == Approx(0.25f).margin(0.25f) for: 0.5f == Approx( 0.25 ) Approx.tests.cpp:: passed: 245.0f == Approx(245.25f).margin(0.25f) for: 245.0f == Approx( 245.25 ) Approx.tests.cpp:: passed: 245.5f == Approx(245.25f).margin(0.25f) for: 245.5f == Approx( 245.25 ) Approx.tests.cpp:: passed: divide( 22, 7 ) == Approx( 3.141 ).epsilon( 0.001 ) for: 3.1428571429 == Approx( 3.141 ) Approx.tests.cpp:: passed: divide( 22, 7 ) != Approx( 3.141 ).epsilon( 0.0001 ) for: 3.1428571429 != Approx( 3.141 ) Approx.tests.cpp:: passed: d != Approx( 1.231 ) for: 1.23 != Approx( 1.231 ) Approx.tests.cpp:: passed: d == Approx( 1.231 ).epsilon( 0.1 ) for: 1.23 == Approx( 1.231 ) Approx.tests.cpp:: passed: 1.23f == Approx( 1.23f ) for: 1.23f == Approx( 1.2300000191 ) Approx.tests.cpp:: passed: 0.0f == Approx( 0.0f ) for: 0.0f == Approx( 0.0 ) Approx.tests.cpp:: passed: 1 == Approx( 1 ) for: 1 == Approx( 1.0 ) Approx.tests.cpp:: passed: 0 == Approx( 0 ) for: 0 == Approx( 0.0 ) Approx.tests.cpp:: passed: 1.0f == Approx( 1 ) for: 1.0f == Approx( 1.0 ) Approx.tests.cpp:: passed: 0 == Approx( dZero) for: 0 == Approx( 0.0 ) Approx.tests.cpp:: passed: 0 == Approx( dSmall ).margin( 0.001 ) for: 0 == Approx( 0.00001 ) Approx.tests.cpp:: passed: 1.234f == Approx( dMedium ) for: 1.234f == Approx( 1.234 ) Approx.tests.cpp:: passed: dMedium == Approx( 1.234f ) for: 1.234 == Approx( 1.2339999676 ) Matchers.tests.cpp:: passed: 1, Predicate(alwaysTrue, "always true") for: 1 matches predicate: "always true" Matchers.tests.cpp:: passed: 1, !Predicate(alwaysFalse, "always false") for: 1 not matches predicate: "always false" Matchers.tests.cpp:: passed: "Hello olleH", Predicate( [] (std::string const& str) -> bool { return str.front() == str.back(); }, "First and last character should be equal") for: "Hello olleH" matches predicate: "First and last character should be equal" Matchers.tests.cpp:: passed: "This wouldn't pass", !Predicate( [] (std::string const& str) -> bool { return str.front() == str.back(); } ) for: "This wouldn't pass" not matches undescribed predicate Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: true Message.tests.cpp:: passed: with 7 messages: 'a := 1' and 'b := 2' and 'c := 3' and 'a + b := 3' and 'a+b := 3' and 'c > b := true' and 'a == 1 := true' Message.tests.cpp:: passed: with 7 messages: 'std::vector{1, 2, 3}[0, 1, 2] := 3' and 'std::vector{1, 2, 3}[(0, 1)] := 2' and 'std::vector{1, 2, 3}[0] := 1' and '(helper_1436{12, -12}) := { 12, -12 }' and '(helper_1436(-12, 12)) := { -12, 12 }' and '(1, 2) := 2' and '(2, 3) := 3' Message.tests.cpp:: passed: with 11 messages: '("comma, in string", "escaped, \", ") := "escaped, ", "' and '"single quote in string,'," := "single quote in string,',"' and '"some escapes, \\,\\\\" := "some escapes, \,\\"' and '"some, ), unmatched, } prenheses {[<" := "some, ), unmatched, } prenheses {[<"' and ''"' := '"'' and ''\'' := '''' and '',' := ','' and ''}' := '}'' and '')' := ')'' and ''(' := '('' and ''{' := '{'' ToStringGeneral.tests.cpp:: passed: true with 1 message: 'i := 2' ToStringGeneral.tests.cpp:: passed: true with 1 message: '3' ToStringGeneral.tests.cpp:: passed: tab == '\t' for: '\t' == '\t' ToStringGeneral.tests.cpp:: passed: newline == '\n' for: '\n' == '\n' ToStringGeneral.tests.cpp:: passed: carr_return == '\r' for: '\r' == '\r' ToStringGeneral.tests.cpp:: passed: form_feed == '\f' for: '\f' == '\f' ToStringGeneral.tests.cpp:: passed: space == ' ' for: ' ' == ' ' ToStringGeneral.tests.cpp:: passed: c == chars[i] for: 'a' == 'a' ToStringGeneral.tests.cpp:: passed: c == chars[i] for: 'z' == 'z' ToStringGeneral.tests.cpp:: passed: c == chars[i] for: 'A' == 'A' ToStringGeneral.tests.cpp:: passed: c == chars[i] for: 'Z' == 'Z' ToStringGeneral.tests.cpp:: passed: null_terminator == '\0' for: 0 == 0 ToStringGeneral.tests.cpp:: passed: c == i for: 2 == 2 ToStringGeneral.tests.cpp:: passed: c == i for: 3 == 3 ToStringGeneral.tests.cpp:: passed: c == i for: 4 == 4 ToStringGeneral.tests.cpp:: passed: c == i for: 5 == 5 Tricky.tests.cpp:: passed: std::vector{constructor_throws{}, constructor_throws{}} Tricky.tests.cpp:: passed: std::vector{constructor_throws{}, constructor_throws{}} Tricky.tests.cpp:: passed: std::vector{1, 2, 3} == std::vector{1, 2, 3} Tricky.tests.cpp:: passed: std::vector{1, 2, 3} == std::vector{1, 2, 3} Tricky.tests.cpp:: passed: std::vector{1, 2} == std::vector{1, 2} for: { 1, 2 } == { 1, 2 } Tricky.tests.cpp:: passed: std::vector{1, 2} == std::vector{1, 2} for: { 1, 2 } == { 1, 2 } Tricky.tests.cpp:: passed: !(std::vector{1, 2} == std::vector{1, 2, 3}) for: !({ 1, 2 } == { 1, 2, 3 }) Tricky.tests.cpp:: passed: !(std::vector{1, 2} == std::vector{1, 2, 3}) for: !({ 1, 2 } == { 1, 2, 3 }) Tricky.tests.cpp:: passed: std::vector{1, 2} == std::vector{1, 2} for: { 1, 2 } == { 1, 2 } Tricky.tests.cpp:: passed: std::vector{1, 2} == std::vector{1, 2} for: { 1, 2 } == { 1, 2 } Tricky.tests.cpp:: passed: true Tricky.tests.cpp:: passed: std::vector{1, 2} == std::vector{1, 2} for: { 1, 2 } == { 1, 2 } Tricky.tests.cpp:: passed: a for: 0x Tricky.tests.cpp:: passed: a == &foo for: 0x == 0x RandomNumberGeneration.tests.cpp:: passed: SimplePcg32{} == SimplePcg32{} for: {?} == {?} RandomNumberGeneration.tests.cpp:: passed: SimplePcg32{ 0 } != SimplePcg32{} for: {?} != {?} RandomNumberGeneration.tests.cpp:: passed: !(SimplePcg32{ 1 } == SimplePcg32{ 2 }) for: !({?} == {?}) RandomNumberGeneration.tests.cpp:: passed: !(SimplePcg32{ 1 } != SimplePcg32{ 1 }) for: !({?} != {?}) Approx.tests.cpp:: passed: td == Approx(10.0) for: StrongDoubleTypedef(10) == Approx( 10.0 ) Approx.tests.cpp:: passed: Approx(10.0) == td for: Approx( 10.0 ) == StrongDoubleTypedef(10) Approx.tests.cpp:: passed: td != Approx(11.0) for: StrongDoubleTypedef(10) != Approx( 11.0 ) Approx.tests.cpp:: passed: Approx(11.0) != td for: Approx( 11.0 ) != StrongDoubleTypedef(10) Approx.tests.cpp:: passed: td <= Approx(10.0) for: StrongDoubleTypedef(10) <= Approx( 10.0 ) Approx.tests.cpp:: passed: td <= Approx(11.0) for: StrongDoubleTypedef(10) <= Approx( 11.0 ) Approx.tests.cpp:: passed: Approx(10.0) <= td for: Approx( 10.0 ) <= StrongDoubleTypedef(10) Approx.tests.cpp:: passed: Approx(9.0) <= td for: Approx( 9.0 ) <= StrongDoubleTypedef(10) Approx.tests.cpp:: passed: td >= Approx(9.0) for: StrongDoubleTypedef(10) >= Approx( 9.0 ) Approx.tests.cpp:: passed: td >= Approx(td) for: StrongDoubleTypedef(10) >= Approx( 10.0 ) Approx.tests.cpp:: passed: Approx(td) >= td for: Approx( 10.0 ) >= StrongDoubleTypedef(10) Approx.tests.cpp:: passed: Approx(11.0) >= td for: Approx( 11.0 ) >= StrongDoubleTypedef(10) Condition.tests.cpp:: passed: 54 == 6*9 for: 54 == 54 Condition.tests.cpp:: passed: ( -1 > 2u ) for: true Condition.tests.cpp:: passed: -1 > 2u for: -1 > 2 Condition.tests.cpp:: passed: ( 2u < -1 ) for: true Condition.tests.cpp:: passed: 2u < -1 for: 2 < -1 Condition.tests.cpp:: passed: ( minInt > 2u ) for: true Condition.tests.cpp:: passed: minInt > 2u for: -2147483648 > 2 Condition.tests.cpp:: passed: i == 1 for: 1 == 1 Condition.tests.cpp:: passed: ui == 2 for: 2 == 2 Condition.tests.cpp:: passed: l == 3 for: 3 == 3 Condition.tests.cpp:: passed: ul == 4 for: 4 == 4 Condition.tests.cpp:: passed: c == 5 for: 5 == 5 Condition.tests.cpp:: passed: uc == 6 for: 6 == 6 Condition.tests.cpp:: passed: 1 == i for: 1 == 1 Condition.tests.cpp:: passed: 2 == ui for: 2 == 2 Condition.tests.cpp:: passed: 3 == l for: 3 == 3 Condition.tests.cpp:: passed: 4 == ul for: 4 == 4 Condition.tests.cpp:: passed: 5 == c for: 5 == 5 Condition.tests.cpp:: passed: 6 == uc for: 6 == 6 Condition.tests.cpp:: passed: (std::numeric_limits::max)() > ul for: 4294967295 (0x) > 4 Matchers.tests.cpp:: failed: testStringForMatching(), Contains("not there", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" contains: "not there" (case insensitive) Matchers.tests.cpp:: failed: testStringForMatching(), Contains("STRING") for: "this string contains 'abc' as a substring" contains: "STRING" Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: elem % 2 == 1 for: 1 == 1 Generators.tests.cpp:: passed: call_count == 1 for: 1 == 1 Generators.tests.cpp:: passed: make_data().size() == test_count for: 6 == 6 Exception.tests.cpp:: failed: unexpected exception with message: 'custom exception - not std'; expression was: throwCustom() Exception.tests.cpp:: failed: unexpected exception with message: 'custom exception - not std'; expression was: throwCustom(), std::exception Exception.tests.cpp:: failed: unexpected exception with message: 'custom std exception' Approx.tests.cpp:: passed: 101.000001 != Approx(100).epsilon(0.01) for: 101.000001 != Approx( 100.0 ) Approx.tests.cpp:: passed: std::pow(10, -5) != Approx(std::pow(10, -7)) for: 0.00001 != Approx( 0.0000001 ) ToString.tests.cpp:: passed: enumInfo->lookup(0) == "Value1" for: Value1 == "Value1" ToString.tests.cpp:: passed: enumInfo->lookup(1) == "Value2" for: Value2 == "Value2" ToString.tests.cpp:: passed: enumInfo->lookup(3) == "{** unexpected enum value **}" for: {** unexpected enum value **} == "{** unexpected enum value **}" Matchers.tests.cpp:: failed: testStringForMatching(), EndsWith("Substring") for: "this string contains 'abc' as a substring" ends with: "Substring" Matchers.tests.cpp:: failed: testStringForMatching(), EndsWith("this", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" ends with: "this" (case insensitive) EnumToString.tests.cpp:: passed: stringify( EnumClass3::Value1 ) == "Value1" for: "Value1" == "Value1" EnumToString.tests.cpp:: passed: stringify( EnumClass3::Value2 ) == "Value2" for: "Value2" == "Value2" EnumToString.tests.cpp:: passed: stringify( EnumClass3::Value3 ) == "Value3" for: "Value3" == "Value3" EnumToString.tests.cpp:: passed: stringify( EnumClass3::Value4 ) == "{** unexpected enum value **}" for: "{** unexpected enum value **}" == "{** unexpected enum value **}" EnumToString.tests.cpp:: passed: stringify( ec3 ) == "Value2" for: "Value2" == "Value2" EnumToString.tests.cpp:: passed: stringify( Bikeshed::Colours::Red ) == "Red" for: "Red" == "Red" EnumToString.tests.cpp:: passed: stringify( Bikeshed::Colours::Blue ) == "Blue" for: "Blue" == "Blue" Approx.tests.cpp:: passed: 101.01 != Approx(100).epsilon(0.01) for: 101.01 != Approx( 100.0 ) Condition.tests.cpp:: failed: data.int_seven == 6 for: 7 == 6 Condition.tests.cpp:: failed: data.int_seven == 8 for: 7 == 8 Condition.tests.cpp:: failed: data.int_seven == 0 for: 7 == 0 Condition.tests.cpp:: failed: data.float_nine_point_one == Approx( 9.11f ) for: 9.1f == Approx( 9.1099996567 ) Condition.tests.cpp:: failed: data.float_nine_point_one == Approx( 9.0f ) for: 9.1f == Approx( 9.0 ) Condition.tests.cpp:: failed: data.float_nine_point_one == Approx( 1 ) for: 9.1f == Approx( 1.0 ) Condition.tests.cpp:: failed: data.float_nine_point_one == Approx( 0 ) for: 9.1f == Approx( 0.0 ) Condition.tests.cpp:: failed: data.double_pi == Approx( 3.1415 ) for: 3.1415926535 == Approx( 3.1415 ) Condition.tests.cpp:: failed: data.str_hello == "goodbye" for: "hello" == "goodbye" Condition.tests.cpp:: failed: data.str_hello == "hell" for: "hello" == "hell" Condition.tests.cpp:: failed: data.str_hello == "hello1" for: "hello" == "hello1" Condition.tests.cpp:: failed: data.str_hello.size() == 6 for: 5 == 6 Condition.tests.cpp:: failed: x == Approx( 1.301 ) for: 1.3 == Approx( 1.301 ) Condition.tests.cpp:: passed: data.int_seven == 7 for: 7 == 7 Condition.tests.cpp:: passed: data.float_nine_point_one == Approx( 9.1f ) for: 9.1f == Approx( 9.1000003815 ) Condition.tests.cpp:: passed: data.double_pi == Approx( 3.1415926535 ) for: 3.1415926535 == Approx( 3.1415926535 ) Condition.tests.cpp:: passed: data.str_hello == "hello" for: "hello" == "hello" Condition.tests.cpp:: passed: "hello" == data.str_hello for: "hello" == "hello" Condition.tests.cpp:: passed: data.str_hello.size() == 5 for: 5 == 5 Condition.tests.cpp:: passed: x == Approx( 1.3 ) for: 1.3 == Approx( 1.3 ) Matchers.tests.cpp:: passed: testStringForMatching(), Equals("this string contains 'abc' as a substring") for: "this string contains 'abc' as a substring" equals: "this string contains 'abc' as a substring" Matchers.tests.cpp:: passed: testStringForMatching(), Equals("this string contains 'ABC' as a substring", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" equals: "this string contains 'abc' as a substring" (case insensitive) Matchers.tests.cpp:: failed: testStringForMatching(), Equals("this string contains 'ABC' as a substring") for: "this string contains 'abc' as a substring" equals: "this string contains 'ABC' as a substring" Matchers.tests.cpp:: failed: testStringForMatching(), Equals("something else", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" equals: "something else" (case insensitive) ToStringGeneral.tests.cpp:: passed: ::Catch::Detail::stringify(WhatException{}) == "This exception has overridden what() method" for: "This exception has overridden what() method" == "This exception has overridden what() method" ToStringGeneral.tests.cpp:: passed: ::Catch::Detail::stringify(OperatorException{}) == "OperatorException" for: "OperatorException" == "OperatorException" ToStringGeneral.tests.cpp:: passed: ::Catch::Detail::stringify(StringMakerException{}) == "StringMakerException" for: "StringMakerException" == "StringMakerException" Matchers.tests.cpp:: failed: expected exception, got none; expression was: doesNotThrow(), SpecialException, ExceptionMatcher{1} Matchers.tests.cpp:: failed: expected exception, got none; expression was: doesNotThrow(), SpecialException, ExceptionMatcher{1} Matchers.tests.cpp:: failed: unexpected exception with message: 'Unknown exception'; expression was: throwsAsInt(1), SpecialException, ExceptionMatcher{1} Matchers.tests.cpp:: failed: unexpected exception with message: 'Unknown exception'; expression was: throwsAsInt(1), SpecialException, ExceptionMatcher{1} Matchers.tests.cpp:: failed: throwsSpecialException(3), SpecialException, ExceptionMatcher{1} for: SpecialException::what special exception has value of 1 Matchers.tests.cpp:: failed: throwsSpecialException(4), SpecialException, ExceptionMatcher{1} for: SpecialException::what special exception has value of 1 Matchers.tests.cpp:: passed: throwsSpecialException(1), SpecialException, ExceptionMatcher{1} for: SpecialException::what special exception has value of 1 Matchers.tests.cpp:: passed: throwsSpecialException(2), SpecialException, ExceptionMatcher{2} for: SpecialException::what special exception has value of 2 Exception.tests.cpp:: passed: thisThrows(), "expected exception" for: "expected exception" equals: "expected exception" Exception.tests.cpp:: passed: thisThrows(), Equals( "expecteD Exception", Catch::CaseSensitive::No ) for: "expected exception" equals: "expected exception" (case insensitive) Exception.tests.cpp:: passed: thisThrows(), StartsWith( "expected" ) for: "expected exception" starts with: "expected" Exception.tests.cpp:: passed: thisThrows(), EndsWith( "exception" ) for: "expected exception" ends with: "exception" Exception.tests.cpp:: passed: thisThrows(), Contains( "except" ) for: "expected exception" contains: "except" Exception.tests.cpp:: passed: thisThrows(), Contains( "exCept", Catch::CaseSensitive::No ) for: "expected exception" contains: "except" (case insensitive) Matchers.tests.cpp:: passed: throwsDerivedException(), DerivedException, Message("DerivedException::what") for: DerivedException::what exception message matches "DerivedException::what" Matchers.tests.cpp:: passed: throwsDerivedException(), DerivedException, !Message("derivedexception::what") for: DerivedException::what not exception message matches "derivedexception::what" Matchers.tests.cpp:: passed: throwsSpecialException(2), SpecialException, !Message("DerivedException::what") for: SpecialException::what not exception message matches "DerivedException::what" Matchers.tests.cpp:: passed: throwsSpecialException(2), SpecialException, Message("SpecialException::what") for: SpecialException::what exception message matches "SpecialException::what" Exception.tests.cpp:: failed: unexpected exception with message: 'expected exception'; expression was: thisThrows(), std::string Exception.tests.cpp:: failed: expected exception, got none; expression was: thisDoesntThrow(), std::domain_error Exception.tests.cpp:: failed: unexpected exception with message: 'expected exception'; expression was: thisThrows() Message.tests.cpp:: failed: explicitly with 1 message: 'This is a failure' Message.tests.cpp:: failed: explicitly Message.tests.cpp:: failed: explicitly with 1 message: 'This is a failure' Message.tests.cpp:: warning: 'This message appears in the output' Misc.tests.cpp:: passed: Factorial(0) == 1 for: 1 == 1 Misc.tests.cpp:: passed: Factorial(1) == 1 for: 1 == 1 Misc.tests.cpp:: passed: Factorial(2) == 2 for: 2 == 2 Misc.tests.cpp:: passed: Factorial(3) == 6 for: 6 == 6 Misc.tests.cpp:: passed: Factorial(10) == 3628800 for: 3628800 (0x) == 3628800 (0x) Matchers.tests.cpp:: passed: 10., WithinRel(11.1, 0.1) for: 10.0 and 11.1 are within 10% of each other Matchers.tests.cpp:: passed: 10., !WithinRel(11.2, 0.1) for: 10.0 not and 11.2 are within 10% of each other Matchers.tests.cpp:: passed: 1., !WithinRel(0., 0.99) for: 1.0 not and 0 are within 99% of each other Matchers.tests.cpp:: passed: -0., WithinRel(0.) for: -0.0 and 0 are within 2.22045e-12% of each other Matchers.tests.cpp:: passed: v1, WithinRel(v2) for: 0.0 and 2.22507e-308 are within 2.22045e-12% of each other Matchers.tests.cpp:: passed: 1., WithinAbs(1., 0) for: 1.0 is within 0.0 of 1.0 Matchers.tests.cpp:: passed: 0., WithinAbs(1., 1) for: 0.0 is within 1.0 of 1.0 Matchers.tests.cpp:: passed: 0., !WithinAbs(1., 0.99) for: 0.0 not is within 0.99 of 1.0 Matchers.tests.cpp:: passed: 0., !WithinAbs(1., 0.99) for: 0.0 not is within 0.99 of 1.0 Matchers.tests.cpp:: passed: 11., !WithinAbs(10., 0.5) for: 11.0 not is within 0.5 of 10.0 Matchers.tests.cpp:: passed: 10., !WithinAbs(11., 0.5) for: 10.0 not is within 0.5 of 11.0 Matchers.tests.cpp:: passed: -10., WithinAbs(-10., 0.5) for: -10.0 is within 0.5 of -10.0 Matchers.tests.cpp:: passed: -10., WithinAbs(-9.6, 0.5) for: -10.0 is within 0.5 of -9.6 Matchers.tests.cpp:: passed: 1., WithinULP(1., 0) for: 1.0 is within 0 ULPs of 1.0000000000000000e+00 ([1.0000000000000000e+00, 1.0000000000000000e+00]) Matchers.tests.cpp:: passed: nextafter(1., 2.), WithinULP(1., 1) for: 1.0 is within 1 ULPs of 1.0000000000000000e+00 ([9.9999999999999989e-01, 1.0000000000000002e+00]) Matchers.tests.cpp:: passed: 0., WithinULP(nextafter(0., 1.), 1) for: 0.0 is within 1 ULPs of 4.9406564584124654e-324 ([0.0000000000000000e+00, 9.8813129168249309e-324]) Matchers.tests.cpp:: passed: 1., WithinULP(nextafter(1., 0.), 1) for: 1.0 is within 1 ULPs of 9.9999999999999989e-01 ([9.9999999999999978e-01, 1.0000000000000000e+00]) Matchers.tests.cpp:: passed: 1., !WithinULP(nextafter(1., 2.), 0) for: 1.0 not is within 0 ULPs of 1.0000000000000002e+00 ([1.0000000000000002e+00, 1.0000000000000002e+00]) Matchers.tests.cpp:: passed: 1., WithinULP(1., 0) for: 1.0 is within 0 ULPs of 1.0000000000000000e+00 ([1.0000000000000000e+00, 1.0000000000000000e+00]) Matchers.tests.cpp:: passed: -0., WithinULP(0., 0) for: -0.0 is within 0 ULPs of 0.0000000000000000e+00 ([0.0000000000000000e+00, 0.0000000000000000e+00]) Matchers.tests.cpp:: passed: 1., WithinAbs(1., 0.5) || WithinULP(2., 1) for: 1.0 ( is within 0.5 of 1.0 or is within 1 ULPs of 2.0000000000000000e+00 ([1.9999999999999998e+00, 2.0000000000000004e+00]) ) Matchers.tests.cpp:: passed: 1., WithinAbs(2., 0.5) || WithinULP(1., 0) for: 1.0 ( is within 0.5 of 2.0 or is within 0 ULPs of 1.0000000000000000e+00 ([1.0000000000000000e+00, 1.0000000000000000e+00]) ) Matchers.tests.cpp:: passed: 0.0001, WithinAbs(0., 0.001) || WithinRel(0., 0.1) for: 0.0001 ( is within 0.001 of 0.0 or and 0 are within 10% of each other ) Matchers.tests.cpp:: passed: WithinAbs(1., 0.) Matchers.tests.cpp:: passed: WithinAbs(1., -1.), std::domain_error Matchers.tests.cpp:: passed: WithinULP(1., 0) Matchers.tests.cpp:: passed: WithinRel(1., 0.) Matchers.tests.cpp:: passed: WithinRel(1., -0.2), std::domain_error Matchers.tests.cpp:: passed: WithinRel(1., 1.), std::domain_error Matchers.tests.cpp:: passed: 10.f, WithinRel(11.1f, 0.1f) for: 10.0f and 11.1 are within 10% of each other Matchers.tests.cpp:: passed: 10.f, !WithinRel(11.2f, 0.1f) for: 10.0f not and 11.2 are within 10% of each other Matchers.tests.cpp:: passed: 1.f, !WithinRel(0.f, 0.99f) for: 1.0f not and 0 are within 99% of each other Matchers.tests.cpp:: passed: -0.f, WithinRel(0.f) for: -0.0f and 0 are within 0.00119209% of each other Matchers.tests.cpp:: passed: v1, WithinRel(v2) for: 0.0f and 1.17549e-38 are within 0.00119209% of each other Matchers.tests.cpp:: passed: 1.f, WithinAbs(1.f, 0) for: 1.0f is within 0.0 of 1.0 Matchers.tests.cpp:: passed: 0.f, WithinAbs(1.f, 1) for: 0.0f is within 1.0 of 1.0 Matchers.tests.cpp:: passed: 0.f, !WithinAbs(1.f, 0.99f) for: 0.0f not is within 0.9900000095 of 1.0 Matchers.tests.cpp:: passed: 0.f, !WithinAbs(1.f, 0.99f) for: 0.0f not is within 0.9900000095 of 1.0 Matchers.tests.cpp:: passed: 0.f, WithinAbs(-0.f, 0) for: 0.0f is within 0.0 of -0.0 Matchers.tests.cpp:: passed: 11.f, !WithinAbs(10.f, 0.5f) for: 11.0f not is within 0.5 of 10.0 Matchers.tests.cpp:: passed: 10.f, !WithinAbs(11.f, 0.5f) for: 10.0f not is within 0.5 of 11.0 Matchers.tests.cpp:: passed: -10.f, WithinAbs(-10.f, 0.5f) for: -10.0f is within 0.5 of -10.0 Matchers.tests.cpp:: passed: -10.f, WithinAbs(-9.6f, 0.5f) for: -10.0f is within 0.5 of -9.6000003815 Matchers.tests.cpp:: passed: 1.f, WithinULP(1.f, 0) for: 1.0f is within 0 ULPs of 1.00000000e+00f ([1.00000000e+00, 1.00000000e+00]) Matchers.tests.cpp:: passed: nextafter(1.f, 2.f), WithinULP(1.f, 1) for: 1.0f is within 1 ULPs of 1.00000000e+00f ([9.99999940e-01, 1.00000012e+00]) Matchers.tests.cpp:: passed: 0.f, WithinULP(nextafter(0.f, 1.f), 1) for: 0.0f is within 1 ULPs of 1.40129846e-45f ([0.00000000e+00, 2.80259693e-45]) Matchers.tests.cpp:: passed: 1.f, WithinULP(nextafter(1.f, 0.f), 1) for: 1.0f is within 1 ULPs of 9.99999940e-01f ([9.99999881e-01, 1.00000000e+00]) Matchers.tests.cpp:: passed: 1.f, !WithinULP(nextafter(1.f, 2.f), 0) for: 1.0f not is within 0 ULPs of 1.00000012e+00f ([1.00000012e+00, 1.00000012e+00]) Matchers.tests.cpp:: passed: 1.f, WithinULP(1.f, 0) for: 1.0f is within 0 ULPs of 1.00000000e+00f ([1.00000000e+00, 1.00000000e+00]) Matchers.tests.cpp:: passed: -0.f, WithinULP(0.f, 0) for: -0.0f is within 0 ULPs of 0.00000000e+00f ([0.00000000e+00, 0.00000000e+00]) Matchers.tests.cpp:: passed: 1.f, WithinAbs(1.f, 0.5) || WithinULP(1.f, 1) for: 1.0f ( is within 0.5 of 1.0 or is within 1 ULPs of 1.00000000e+00f ([9.99999940e-01, 1.00000012e+00]) ) Matchers.tests.cpp:: passed: 1.f, WithinAbs(2.f, 0.5) || WithinULP(1.f, 0) for: 1.0f ( is within 0.5 of 2.0 or is within 0 ULPs of 1.00000000e+00f ([1.00000000e+00, 1.00000000e+00]) ) Matchers.tests.cpp:: passed: 0.0001f, WithinAbs(0.f, 0.001f) || WithinRel(0.f, 0.1f) for: 0.0001f ( is within 0.001 of 0.0 or and 0 are within 10% of each other ) Matchers.tests.cpp:: passed: WithinAbs(1.f, 0.f) Matchers.tests.cpp:: passed: WithinAbs(1.f, -1.f), std::domain_error Matchers.tests.cpp:: passed: WithinULP(1.f, 0) Matchers.tests.cpp:: passed: WithinULP(1.f, static_cast(-1)), std::domain_error Matchers.tests.cpp:: passed: WithinRel(1.f, 0.f) Matchers.tests.cpp:: passed: WithinRel(1.f, -0.2f), std::domain_error Matchers.tests.cpp:: passed: WithinRel(1.f, 1.f), std::domain_error Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: filter([] (int) {return false; }, value(1)), Catch::GeneratorException Generators.tests.cpp:: passed: i < 4 for: 1 < 4 Generators.tests.cpp:: passed: i < 4 for: 2 < 4 Generators.tests.cpp:: passed: i < 4 for: 3 < 4 Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: i % 2 == 0 for: 0 == 0 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: i.size() == 1 for: 1 == 1 Generators.tests.cpp:: passed: j > 0 for: 1 > 0 Generators.tests.cpp:: passed: j > 0 for: 2 > 0 Generators.tests.cpp:: passed: j > 0 for: 3 > 0 Generators.tests.cpp:: passed: j > 0 for: 1 > 0 Generators.tests.cpp:: passed: j > 0 for: 2 > 0 Generators.tests.cpp:: passed: j > 0 for: 3 > 0 Generators.tests.cpp:: passed: chunk2.size() == 2 for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() == chunk2.back() for: 1 == 1 Generators.tests.cpp:: passed: chunk2.size() == 2 for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() == chunk2.back() for: 2 == 2 Generators.tests.cpp:: passed: chunk2.size() == 2 for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() == chunk2.back() for: 3 == 3 Generators.tests.cpp:: passed: chunk2.size() == 2 for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() == chunk2.back() for: 1 == 1 Generators.tests.cpp:: passed: chunk2.front() < 3 for: 1 < 3 Generators.tests.cpp:: passed: chunk2.size() == 2 for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() == chunk2.back() for: 2 == 2 Generators.tests.cpp:: passed: chunk2.front() < 3 for: 2 < 3 Generators.tests.cpp:: passed: chunk2.size() == 0 for: 0 == 0 Generators.tests.cpp:: passed: chunk2.size() == 0 for: 0 == 0 Generators.tests.cpp:: passed: chunk2.size() == 0 for: 0 == 0 Generators.tests.cpp:: passed: chunk(2, value(1)), Catch::GeneratorException Generators.tests.cpp:: passed: j < i for: -3 < 1 Generators.tests.cpp:: passed: j < i for: -2 < 1 Generators.tests.cpp:: passed: j < i for: -1 < 1 Generators.tests.cpp:: passed: 4u * i > str.size() for: 4 > 1 Generators.tests.cpp:: passed: 4u * i > str.size() for: 4 > 2 Generators.tests.cpp:: passed: 4u * i > str.size() for: 4 > 3 Generators.tests.cpp:: passed: j < i for: -3 < 2 Generators.tests.cpp:: passed: j < i for: -2 < 2 Generators.tests.cpp:: passed: j < i for: -1 < 2 Generators.tests.cpp:: passed: 4u * i > str.size() for: 8 > 1 Generators.tests.cpp:: passed: 4u * i > str.size() for: 8 > 2 Generators.tests.cpp:: passed: 4u * i > str.size() for: 8 > 3 Generators.tests.cpp:: passed: j < i for: -3 < 3 Generators.tests.cpp:: passed: j < i for: -2 < 3 Generators.tests.cpp:: passed: j < i for: -1 < 3 Generators.tests.cpp:: passed: 4u * i > str.size() for: 12 > 1 Generators.tests.cpp:: passed: 4u * i > str.size() for: 12 > 2 Generators.tests.cpp:: passed: 4u * i > str.size() for: 12 > 3 GeneratorsImpl.tests.cpp:: passed: gen.get() == 123 for: 123 == 123 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 3 for: 3 == 3 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 4 for: 4 == 4 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 0 for: 0 == 0 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get().size() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.get() == "aa" for: "aa" == "aa" GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == "bb" for: "bb" == "bb" GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == "cc" for: "cc" == "cc" GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 3 for: 3 == 3 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: filter([] (int) { return false; }, value(1)), Catch::GeneratorException GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 2.0 for: 2.0 == 2.0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 4.0 for: 4.0 == 4.0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 6.0 for: 6.0 == 6.0 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 2.0 for: 2.0 == 2.0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 4.0 for: 4.0 == 4.0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 6.0 for: 6.0 == 6.0 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 3 for: 3 == 3 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 3 for: 3 == 3 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 3 for: 3 == 3 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == -2 for: -2 == -2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 0 for: 0 == 0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 1 for: 1 == 1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 0 for: 0 == 0 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == -7 for: -7 == -7 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == -7 for: -7 == -7 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == -7 for: -7 == -7 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -1.0 == Approx( -1.0 ) with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.9 == Approx( -0.9 ) with 1 message: 'Current expected value is -0.9' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.9' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.8 == Approx( -0.8 ) with 1 message: 'Current expected value is -0.8' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.8' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.7 == Approx( -0.7 ) with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.6 == Approx( -0.6 ) with 1 message: 'Current expected value is -0.6' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.6' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.5 == Approx( -0.5 ) with 1 message: 'Current expected value is -0.5' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.5' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.4 == Approx( -0.4 ) with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.3 == Approx( -0.3 ) with 1 message: 'Current expected value is -0.3' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.3' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.2 == Approx( -0.2 ) with 1 message: 'Current expected value is -0.2' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.2' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.1 == Approx( -0.1 ) with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.0 == Approx( -0.0 ) with 1 message: 'Current expected value is -1.38778e-16' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -1.38778e-16' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.1 == Approx( 0.1 ) with 1 message: 'Current expected value is 0.1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.2 == Approx( 0.2 ) with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.3 == Approx( 0.3 ) with 1 message: 'Current expected value is 0.3' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.3' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.4 == Approx( 0.4 ) with 1 message: 'Current expected value is 0.4' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.4' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.5 == Approx( 0.5 ) with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.6 == Approx( 0.6 ) with 1 message: 'Current expected value is 0.6' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.6' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.7 == Approx( 0.7 ) with 1 message: 'Current expected value is 0.7' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.7' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.8 == Approx( 0.8 ) with 1 message: 'Current expected value is 0.8' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.8' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.9 == Approx( 0.9 ) with 1 message: 'Current expected value is 0.9' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.9' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx( rangeEnd ) for: 1.0 == Approx( 1.0 ) GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -1.0 == Approx( -1.0 ) with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.7 == Approx( -0.7 ) with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.4 == Approx( -0.4 ) with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.1 == Approx( -0.1 ) with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.2 == Approx( 0.2 ) with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.5 == Approx( 0.5 ) with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -1.0 == Approx( -1.0 ) with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.7 == Approx( -0.7 ) with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.7' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.4 == Approx( -0.4 ) with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.4' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: -0.1 == Approx( -0.1 ) with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is -0.1' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.2 == Approx( 0.2 ) with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.2' GeneratorsImpl.tests.cpp:: passed: gen.get() == Approx(expected) for: 0.5 == Approx( 0.5 ) with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: gen.next() for: true with 1 message: 'Current expected value is 0.5' GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false GeneratorsImpl.tests.cpp:: passed: gen.get() == 5 for: 5 == 5 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == 2 for: 2 == 2 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -1 for: -1 == -1 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -4 for: -4 == -4 GeneratorsImpl.tests.cpp:: passed: gen.next() for: true GeneratorsImpl.tests.cpp:: passed: gen.get() == -7 for: -7 == -7 GeneratorsImpl.tests.cpp:: passed: !(gen.next()) for: !false Approx.tests.cpp:: passed: d >= Approx( 1.22 ) for: 1.23 >= Approx( 1.22 ) Approx.tests.cpp:: passed: d >= Approx( 1.23 ) for: 1.23 >= Approx( 1.23 ) Approx.tests.cpp:: passed: !(d >= Approx( 1.24 )) for: !(1.23 >= Approx( 1.24 )) Approx.tests.cpp:: passed: d >= Approx( 1.24 ).epsilon(0.1) for: 1.23 >= Approx( 1.24 ) Message.tests.cpp:: warning: 'this is a message' with 1 message: 'this is a warning' Message.tests.cpp:: failed: a == 1 for: 2 == 1 with 2 messages: 'this message should be logged' and 'so should this' Message.tests.cpp:: passed: a == 2 for: 2 == 2 with 1 message: 'this message may be logged later' Message.tests.cpp:: failed: a == 1 for: 2 == 1 with 2 messages: 'this message may be logged later' and 'this message should be logged' Message.tests.cpp:: failed: a == 0 for: 2 == 0 with 3 messages: 'this message may be logged later' and 'this message should be logged' and 'and this, but later' Message.tests.cpp:: passed: a == 2 for: 2 == 2 with 4 messages: 'this message may be logged later' and 'this message should be logged' and 'and this, but later' and 'but not this' Message.tests.cpp:: passed: i < 10 for: 0 < 10 with 2 messages: 'current counter 0' and 'i := 0' Message.tests.cpp:: passed: i < 10 for: 1 < 10 with 2 messages: 'current counter 1' and 'i := 1' Message.tests.cpp:: passed: i < 10 for: 2 < 10 with 2 messages: 'current counter 2' and 'i := 2' Message.tests.cpp:: passed: i < 10 for: 3 < 10 with 2 messages: 'current counter 3' and 'i := 3' Message.tests.cpp:: passed: i < 10 for: 4 < 10 with 2 messages: 'current counter 4' and 'i := 4' Message.tests.cpp:: passed: i < 10 for: 5 < 10 with 2 messages: 'current counter 5' and 'i := 5' Message.tests.cpp:: passed: i < 10 for: 6 < 10 with 2 messages: 'current counter 6' and 'i := 6' Message.tests.cpp:: passed: i < 10 for: 7 < 10 with 2 messages: 'current counter 7' and 'i := 7' Message.tests.cpp:: passed: i < 10 for: 8 < 10 with 2 messages: 'current counter 8' and 'i := 8' Message.tests.cpp:: passed: i < 10 for: 9 < 10 with 2 messages: 'current counter 9' and 'i := 9' Message.tests.cpp:: failed: i < 10 for: 10 < 10 with 2 messages: 'current counter 10' and 'i := 10' Condition.tests.cpp:: failed: data.int_seven != 7 for: 7 != 7 Condition.tests.cpp:: failed: data.float_nine_point_one != Approx( 9.1f ) for: 9.1f != Approx( 9.1000003815 ) Condition.tests.cpp:: failed: data.double_pi != Approx( 3.1415926535 ) for: 3.1415926535 != Approx( 3.1415926535 ) Condition.tests.cpp:: failed: data.str_hello != "hello" for: "hello" != "hello" Condition.tests.cpp:: failed: data.str_hello.size() != 5 for: 5 != 5 Condition.tests.cpp:: passed: data.int_seven != 6 for: 7 != 6 Condition.tests.cpp:: passed: data.int_seven != 8 for: 7 != 8 Condition.tests.cpp:: passed: data.float_nine_point_one != Approx( 9.11f ) for: 9.1f != Approx( 9.1099996567 ) Condition.tests.cpp:: passed: data.float_nine_point_one != Approx( 9.0f ) for: 9.1f != Approx( 9.0 ) Condition.tests.cpp:: passed: data.float_nine_point_one != Approx( 1 ) for: 9.1f != Approx( 1.0 ) Condition.tests.cpp:: passed: data.float_nine_point_one != Approx( 0 ) for: 9.1f != Approx( 0.0 ) Condition.tests.cpp:: passed: data.double_pi != Approx( 3.1415 ) for: 3.1415926535 != Approx( 3.1415 ) Condition.tests.cpp:: passed: data.str_hello != "goodbye" for: "hello" != "goodbye" Condition.tests.cpp:: passed: data.str_hello != "hell" for: "hello" != "hell" Condition.tests.cpp:: passed: data.str_hello != "hello1" for: "hello" != "hello1" Condition.tests.cpp:: passed: data.str_hello.size() != 6 for: 5 != 6 Approx.tests.cpp:: passed: d <= Approx( 1.24 ) for: 1.23 <= Approx( 1.24 ) Approx.tests.cpp:: passed: d <= Approx( 1.23 ) for: 1.23 <= Approx( 1.23 ) Approx.tests.cpp:: passed: !(d <= Approx( 1.22 )) for: !(1.23 <= Approx( 1.22 )) Approx.tests.cpp:: passed: d <= Approx( 1.22 ).epsilon(0.1) for: 1.23 <= Approx( 1.22 ) Misc.tests.cpp:: passed: with 1 message: 'was called' Matchers.tests.cpp:: passed: testStringForMatching(), Contains("string") && Contains("abc") && Contains("substring") && Contains("contains") for: "this string contains 'abc' as a substring" ( contains: "string" and contains: "abc" and contains: "substring" and contains: "contains" ) Matchers.tests.cpp:: passed: testStringForMatching(), Contains("string") || Contains("different") || Contains("random") for: "this string contains 'abc' as a substring" ( contains: "string" or contains: "different" or contains: "random" ) Matchers.tests.cpp:: passed: testStringForMatching2(), Contains("string") || Contains("different") || Contains("random") for: "some completely different text that contains one common word" ( contains: "string" or contains: "different" or contains: "random" ) Matchers.tests.cpp:: passed: testStringForMatching(), (Contains("string") || Contains("different")) && Contains("substring") for: "this string contains 'abc' as a substring" ( ( contains: "string" or contains: "different" ) and contains: "substring" ) Matchers.tests.cpp:: failed: testStringForMatching(), (Contains("string") || Contains("different")) && Contains("random") for: "this string contains 'abc' as a substring" ( ( contains: "string" or contains: "different" ) and contains: "random" ) Matchers.tests.cpp:: passed: testStringForMatching(), !Contains("different") for: "this string contains 'abc' as a substring" not contains: "different" Matchers.tests.cpp:: failed: testStringForMatching(), !Contains("substring") for: "this string contains 'abc' as a substring" not contains: "substring" Exception.tests.cpp:: passed: thisThrows(), "expected exception" for: "expected exception" equals: "expected exception" Exception.tests.cpp:: failed: thisThrows(), "should fail" for: "expected exception" equals: "should fail" Generators.tests.cpp:: passed: values > -6 for: 3 > -6 Generators.tests.cpp:: passed: values > -6 for: 4 > -6 Generators.tests.cpp:: passed: values > -6 for: 5 > -6 Generators.tests.cpp:: passed: values > -6 for: 6 > -6 Generators.tests.cpp:: passed: values > -6 for: -5 > -6 Generators.tests.cpp:: passed: values > -6 for: -4 > -6 Generators.tests.cpp:: passed: values > -6 for: 90 > -6 Generators.tests.cpp:: passed: values > -6 for: 91 > -6 Generators.tests.cpp:: passed: values > -6 for: 92 > -6 Generators.tests.cpp:: passed: values > -6 for: 93 > -6 Generators.tests.cpp:: passed: values > -6 for: 94 > -6 Generators.tests.cpp:: passed: values > -6 for: 95 > -6 Generators.tests.cpp:: passed: values > -6 for: 96 > -6 Generators.tests.cpp:: passed: values > -6 for: 97 > -6 Generators.tests.cpp:: passed: values > -6 for: 98 > -6 Generators.tests.cpp:: passed: values > -6 for: 99 > -6 Misc.tests.cpp:: warning: 'This one ran' Exception.tests.cpp:: failed: unexpected exception with message: 'custom exception' Tricky.tests.cpp:: passed: True for: {?} Tricky.tests.cpp:: passed: !False for: true Tricky.tests.cpp:: passed: !(False) for: !{?} Compilation.tests.cpp:: passed: with 1 message: 'std::is_void::value' Compilation.tests.cpp:: passed: with 1 message: '!(std::is_void::value)' Condition.tests.cpp:: failed: data.int_seven > 7 for: 7 > 7 Condition.tests.cpp:: failed: data.int_seven < 7 for: 7 < 7 Condition.tests.cpp:: failed: data.int_seven > 8 for: 7 > 8 Condition.tests.cpp:: failed: data.int_seven < 6 for: 7 < 6 Condition.tests.cpp:: failed: data.int_seven < 0 for: 7 < 0 Condition.tests.cpp:: failed: data.int_seven < -1 for: 7 < -1 Condition.tests.cpp:: failed: data.int_seven >= 8 for: 7 >= 8 Condition.tests.cpp:: failed: data.int_seven <= 6 for: 7 <= 6 Condition.tests.cpp:: failed: data.float_nine_point_one < 9 for: 9.1f < 9 Condition.tests.cpp:: failed: data.float_nine_point_one > 10 for: 9.1f > 10 Condition.tests.cpp:: failed: data.float_nine_point_one > 9.2 for: 9.1f > 9.2 Condition.tests.cpp:: failed: data.str_hello > "hello" for: "hello" > "hello" Condition.tests.cpp:: failed: data.str_hello < "hello" for: "hello" < "hello" Condition.tests.cpp:: failed: data.str_hello > "hellp" for: "hello" > "hellp" Condition.tests.cpp:: failed: data.str_hello > "z" for: "hello" > "z" Condition.tests.cpp:: failed: data.str_hello < "hellm" for: "hello" < "hellm" Condition.tests.cpp:: failed: data.str_hello < "a" for: "hello" < "a" Condition.tests.cpp:: failed: data.str_hello >= "z" for: "hello" >= "z" Condition.tests.cpp:: failed: data.str_hello <= "a" for: "hello" <= "a" Condition.tests.cpp:: passed: data.int_seven < 8 for: 7 < 8 Condition.tests.cpp:: passed: data.int_seven > 6 for: 7 > 6 Condition.tests.cpp:: passed: data.int_seven > 0 for: 7 > 0 Condition.tests.cpp:: passed: data.int_seven > -1 for: 7 > -1 Condition.tests.cpp:: passed: data.int_seven >= 7 for: 7 >= 7 Condition.tests.cpp:: passed: data.int_seven >= 6 for: 7 >= 6 Condition.tests.cpp:: passed: data.int_seven <= 7 for: 7 <= 7 Condition.tests.cpp:: passed: data.int_seven <= 8 for: 7 <= 8 Condition.tests.cpp:: passed: data.float_nine_point_one > 9 for: 9.1f > 9 Condition.tests.cpp:: passed: data.float_nine_point_one < 10 for: 9.1f < 10 Condition.tests.cpp:: passed: data.float_nine_point_one < 9.2 for: 9.1f < 9.2 Condition.tests.cpp:: passed: data.str_hello <= "hello" for: "hello" <= "hello" Condition.tests.cpp:: passed: data.str_hello >= "hello" for: "hello" >= "hello" Condition.tests.cpp:: passed: data.str_hello < "hellp" for: "hello" < "hellp" Condition.tests.cpp:: passed: data.str_hello < "zebra" for: "hello" < "zebra" Condition.tests.cpp:: passed: data.str_hello > "hellm" for: "hello" > "hellm" Condition.tests.cpp:: passed: data.str_hello > "a" for: "hello" > "a" RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 4242248763 (0x) == 4242248763 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1867888929 (0x) == 1867888929 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1276619030 (0x) == 1276619030 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1911218783 (0x) == 1911218783 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1827115164 (0x) == 1827115164 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1472234645 (0x) == 1472234645 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 868832940 (0x) == 868832940 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 570883446 (0x) == 570883446 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 889299803 (0x) == 889299803 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 4261393167 (0x) == 4261393167 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 1472234645 (0x) == 1472234645 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 868832940 (0x) == 868832940 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 570883446 (0x) == 570883446 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 889299803 (0x) == 889299803 (0x) RandomNumberGeneration.tests.cpp:: passed: rng() == 0x for: 4261393167 (0x) == 4261393167 (0x) Message.tests.cpp:: failed: explicitly with 1 message: 'Message from section one' Message.tests.cpp:: failed: explicitly with 1 message: 'Message from section two' CmdLine.tests.cpp:: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: parseTestSpec( "*a" ).matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: parseTestSpec( "a*" ).matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: parseTestSpec( "*a*" ).matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == false for: false == false CmdLine.tests.cpp:: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *tcA ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcB ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcC ) == false for: false == false CmdLine.tests.cpp:: passed: spec.matches( *tcD ) == true for: true == true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark" ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( "aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( "aardvark" ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark" ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( "aardvark " ) ) for: true CmdLine.tests.cpp:: passed: spec.matches( *fakeTestCase( "aardvark" ) ) for: true Condition.tests.cpp:: passed: p == 0 for: 0 == 0 Condition.tests.cpp:: passed: p == pNULL for: 0 == 0 Condition.tests.cpp:: passed: p != 0 for: 0x != 0 Condition.tests.cpp:: passed: cp != 0 for: 0x != 0 Condition.tests.cpp:: passed: cpc != 0 for: 0x != 0 Condition.tests.cpp:: passed: returnsNull() == 0 for: {null string} == 0 Condition.tests.cpp:: passed: returnsConstNull() == 0 for: {null string} == 0 Condition.tests.cpp:: passed: 0 != p for: 0 != 0x ToStringGeneral.tests.cpp:: passed: str1.size() == 3 + 5 for: 8 == 8 ToStringGeneral.tests.cpp:: passed: str2.size() == 3 + 10 for: 13 == 13 ToStringGeneral.tests.cpp:: passed: str1.size() == 2 + 5 for: 7 == 7 ToStringGeneral.tests.cpp:: passed: str2.size() == 2 + 15 for: 17 == 17 Matchers.tests.cpp:: passed: "foo", Predicate([] (const char* const&) { return true; }) for: "foo" matches undescribed predicate CmdLine.tests.cpp:: passed: result for: {?} CmdLine.tests.cpp:: passed: config.processName == "" for: "" == "" CmdLine.tests.cpp:: passed: result for: {?} CmdLine.tests.cpp:: passed: config.processName == "test" for: "test" == "test" CmdLine.tests.cpp:: passed: config.shouldDebugBreak == false for: false == false CmdLine.tests.cpp:: passed: config.abortAfter == -1 for: -1 == -1 CmdLine.tests.cpp:: passed: config.noThrow == false for: false == false CmdLine.tests.cpp:: passed: config.reporterName == "console" for: "console" == "console" CmdLine.tests.cpp:: passed: !(cfg.hasTestFilters()) for: !false CmdLine.tests.cpp:: passed: result for: {?} CmdLine.tests.cpp:: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("notIncluded")) == false for: false == false CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("test1")) for: true CmdLine.tests.cpp:: passed: result for: {?} CmdLine.tests.cpp:: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("test1")) == false for: false == false CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) for: true CmdLine.tests.cpp:: passed: result for: {?} CmdLine.tests.cpp:: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("test1")) == false for: false == false CmdLine.tests.cpp:: passed: cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) for: true CmdLine.tests.cpp:: passed: cli.parse({"test", "-r", "console"}) for: {?} CmdLine.tests.cpp:: passed: config.reporterName == "console" for: "console" == "console" CmdLine.tests.cpp:: passed: cli.parse({"test", "-r", "xml"}) for: {?} CmdLine.tests.cpp:: passed: config.reporterName == "xml" for: "xml" == "xml" CmdLine.tests.cpp:: passed: cli.parse({"test", "--reporter", "junit"}) for: {?} CmdLine.tests.cpp:: passed: config.reporterName == "junit" for: "junit" == "junit" CmdLine.tests.cpp:: passed: !(cli.parse({ "test", "-r", "xml", "-r", "junit" })) for: !{?} CmdLine.tests.cpp:: passed: !result for: true CmdLine.tests.cpp:: passed: result.errorMessage(), Contains("Unrecognized reporter") for: "Unrecognized reporter, 'unsupported'. Check available with --list-reporters" contains: "Unrecognized reporter" CmdLine.tests.cpp:: passed: cli.parse({"test", "-b"}) for: {?} CmdLine.tests.cpp:: passed: config.shouldDebugBreak == true for: true == true CmdLine.tests.cpp:: passed: cli.parse({"test", "--break"}) for: {?} CmdLine.tests.cpp:: passed: config.shouldDebugBreak for: true CmdLine.tests.cpp:: passed: cli.parse({"test", "-a"}) for: {?} CmdLine.tests.cpp:: passed: config.abortAfter == 1 for: 1 == 1 CmdLine.tests.cpp:: passed: cli.parse({"test", "-x", "2"}) for: {?} CmdLine.tests.cpp:: passed: config.abortAfter == 2 for: 2 == 2 CmdLine.tests.cpp:: passed: !result for: true CmdLine.tests.cpp:: passed: result.errorMessage(), Contains("convert") && Contains("oops") for: "Unable to convert 'oops' to destination type" ( contains: "convert" and contains: "oops" ) CmdLine.tests.cpp:: passed: cli.parse({"test", "-e"}) for: {?} CmdLine.tests.cpp:: passed: config.noThrow for: true CmdLine.tests.cpp:: passed: cli.parse({"test", "--nothrow"}) for: {?} CmdLine.tests.cpp:: passed: config.noThrow for: true CmdLine.tests.cpp:: passed: cli.parse({"test", "-o", "filename.ext"}) for: {?} CmdLine.tests.cpp:: passed: config.outputFilename == "filename.ext" for: "filename.ext" == "filename.ext" CmdLine.tests.cpp:: passed: cli.parse({"test", "--out", "filename.ext"}) for: {?} CmdLine.tests.cpp:: passed: config.outputFilename == "filename.ext" for: "filename.ext" == "filename.ext" CmdLine.tests.cpp:: passed: cli.parse({"test", "-abe"}) for: {?} CmdLine.tests.cpp:: passed: config.abortAfter == 1 for: 1 == 1 CmdLine.tests.cpp:: passed: config.shouldDebugBreak for: true CmdLine.tests.cpp:: passed: config.noThrow == true for: true == true CmdLine.tests.cpp:: passed: cli.parse({"test"}) for: {?} CmdLine.tests.cpp:: passed: config.useColour == UseColour::Auto for: 0 == 0 CmdLine.tests.cpp:: passed: cli.parse({"test", "--use-colour", "auto"}) for: {?} CmdLine.tests.cpp:: passed: config.useColour == UseColour::Auto for: 0 == 0 CmdLine.tests.cpp:: passed: cli.parse({"test", "--use-colour", "yes"}) for: {?} CmdLine.tests.cpp:: passed: config.useColour == UseColour::Yes for: 1 == 1 CmdLine.tests.cpp:: passed: cli.parse({"test", "--use-colour", "no"}) for: {?} CmdLine.tests.cpp:: passed: config.useColour == UseColour::No for: 2 == 2 CmdLine.tests.cpp:: passed: !result for: true CmdLine.tests.cpp:: passed: result.errorMessage(), Contains( "colour mode must be one of" ) for: "colour mode must be one of: auto, yes or no. 'wrong' not recognised" contains: "colour mode must be one of" CmdLine.tests.cpp:: passed: cli.parse({ "test", "--benchmark-samples=200" }) for: {?} CmdLine.tests.cpp:: passed: config.benchmarkSamples == 200 for: 200 == 200 CmdLine.tests.cpp:: passed: cli.parse({ "test", "--benchmark-resamples=20000" }) for: {?} CmdLine.tests.cpp:: passed: config.benchmarkResamples == 20000 for: 20000 (0x) == 20000 (0x) CmdLine.tests.cpp:: passed: cli.parse({ "test", "--benchmark-confidence-interval=0.99" }) for: {?} CmdLine.tests.cpp:: passed: config.benchmarkConfidenceInterval == Catch::Detail::Approx(0.99) for: 0.99 == Approx( 0.99 ) CmdLine.tests.cpp:: passed: cli.parse({ "test", "--benchmark-no-analysis" }) for: {?} CmdLine.tests.cpp:: passed: config.benchmarkNoAnalysis for: true Misc.tests.cpp:: passed: std::tuple_size::value >= 1 for: 3 >= 1 Misc.tests.cpp:: passed: std::tuple_size::value >= 1 for: 2 >= 1 Misc.tests.cpp:: passed: std::tuple_size::value >= 1 for: 1 >= 1 Decomposition.tests.cpp:: failed: truthy(false) for: Hey, its truthy! Matchers.tests.cpp:: failed: testStringForMatching(), Matches("this STRING contains 'abc' as a substring") for: "this string contains 'abc' as a substring" matches "this STRING contains 'abc' as a substring" case sensitively Matchers.tests.cpp:: failed: testStringForMatching(), Matches("contains 'abc' as a substring") for: "this string contains 'abc' as a substring" matches "contains 'abc' as a substring" case sensitively Matchers.tests.cpp:: failed: testStringForMatching(), Matches("this string contains 'abc' as a") for: "this string contains 'abc' as a substring" matches "this string contains 'abc' as a" case sensitively Matchers.tests.cpp:: passed: actual, !UnorderedEquals(expected) for: { 'a', 'b' } not UnorderedEquals: { 'c', 'b' } Message.tests.cpp:: passed: with 1 message: 'this is a success' Message.tests.cpp:: passed: BDD.tests.cpp:: passed: before == 0 for: 0 == 0 BDD.tests.cpp:: passed: after > before for: 1 > 0 BDD.tests.cpp:: passed: itDoesThis() for: true BDD.tests.cpp:: passed: itDoesThat() for: true BDD.tests.cpp:: passed: with 1 message: 'boo!' BDD.tests.cpp:: passed: v.size() == 0 for: 0 == 0 BDD.tests.cpp:: passed: v.size() == 10 for: 10 == 10 BDD.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 BDD.tests.cpp:: passed: v.size() == 5 for: 5 == 5 BDD.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 BDD.tests.cpp:: passed: v.size() == 0 for: 0 == 0 BDD.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 BDD.tests.cpp:: passed: v.size() == 0 for: 0 == 0 A string sent directly to stdout A string sent directly to stderr A string sent to stderr via clog Approx.tests.cpp:: passed: d == Approx( 1.23 ) for: 1.23 == Approx( 1.23 ) Approx.tests.cpp:: passed: d != Approx( 1.22 ) for: 1.23 != Approx( 1.22 ) Approx.tests.cpp:: passed: d != Approx( 1.24 ) for: 1.23 != Approx( 1.24 ) Approx.tests.cpp:: passed: d == 1.23_a for: 1.23 == Approx( 1.23 ) Approx.tests.cpp:: passed: d != 1.22_a for: 1.23 != Approx( 1.22 ) Approx.tests.cpp:: passed: Approx( d ) == 1.23 for: Approx( 1.23 ) == 1.23 Approx.tests.cpp:: passed: Approx( d ) != 1.22 for: Approx( 1.23 ) != 1.22 Approx.tests.cpp:: passed: Approx( d ) != 1.24 for: Approx( 1.23 ) != 1.24 Message from section one Message from section two Matchers.tests.cpp:: failed: testStringForMatching(), StartsWith("This String") for: "this string contains 'abc' as a substring" starts with: "This String" Matchers.tests.cpp:: failed: testStringForMatching(), StartsWith("string", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" starts with: "string" (case insensitive) ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify(singular) == "{ 1 }" for: "{ 1 }" == "{ 1 }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify(arr) == "{ 3, 2, 1 }" for: "{ 3, 2, 1 }" == "{ 3, 2, 1 }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify(arr) == R"({ { "1:1", "1:2", "1:3" }, { "2:1", "2:2" } })" for: "{ { "1:1", "1:2", "1:3" }, { "2:1", "2:2" } }" == "{ { "1:1", "1:2", "1:3" }, { "2:1", "2:2" } }" Matchers.tests.cpp:: passed: testStringForMatching(), Contains("string") for: "this string contains 'abc' as a substring" contains: "string" Matchers.tests.cpp:: passed: testStringForMatching(), Contains("string", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" contains: "string" (case insensitive) Matchers.tests.cpp:: passed: testStringForMatching(), Contains("abc") for: "this string contains 'abc' as a substring" contains: "abc" Matchers.tests.cpp:: passed: testStringForMatching(), Contains("aBC", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" contains: "abc" (case insensitive) Matchers.tests.cpp:: passed: testStringForMatching(), StartsWith("this") for: "this string contains 'abc' as a substring" starts with: "this" Matchers.tests.cpp:: passed: testStringForMatching(), StartsWith("THIS", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" starts with: "this" (case insensitive) Matchers.tests.cpp:: passed: testStringForMatching(), EndsWith("substring") for: "this string contains 'abc' as a substring" ends with: "substring" Matchers.tests.cpp:: passed: testStringForMatching(), EndsWith(" SuBsTrInG", Catch::CaseSensitive::No) for: "this string contains 'abc' as a substring" ends with: " substring" (case insensitive) String.tests.cpp:: passed: empty.empty() for: true String.tests.cpp:: passed: empty.size() == 0 for: 0 == 0 String.tests.cpp:: passed: empty.isNullTerminated() for: true String.tests.cpp:: passed: std::strcmp( empty.c_str(), "" ) == 0 for: 0 == 0 String.tests.cpp:: passed: s.empty() == false for: false == false String.tests.cpp:: passed: s.size() == 5 for: 5 == 5 String.tests.cpp:: passed: s.isNullTerminated() for: true String.tests.cpp:: passed: std::strcmp( rawChars, "hello" ) == 0 for: 0 == 0 String.tests.cpp:: passed: s.c_str() String.tests.cpp:: passed: s.c_str() == rawChars for: "hello" == "hello" String.tests.cpp:: passed: s.data() == rawChars for: "hello" == "hello" String.tests.cpp:: passed: original == "original" String.tests.cpp:: passed: !(original.isNullTerminated()) for: !false String.tests.cpp:: passed: original.c_str() String.tests.cpp:: passed: original.data() String.tests.cpp:: passed: ss.empty() == false for: false == false String.tests.cpp:: passed: ss.size() == 5 for: 5 == 5 String.tests.cpp:: passed: std::strncmp( ss.data(), "hello", 5 ) == 0 for: 0 == 0 String.tests.cpp:: passed: ss == "hello" for: hello == "hello" String.tests.cpp:: passed: ss.size() == 6 for: 6 == 6 String.tests.cpp:: passed: std::strcmp( ss.c_str(), "world!" ) == 0 for: 0 == 0 String.tests.cpp:: passed: s.data() == s2.data() for: "hello world!" == "hello world!" String.tests.cpp:: passed: s.data() == ss.data() for: "hello world!" == "hello world!" String.tests.cpp:: passed: s.substr(s.size() + 1, 123).empty() for: true String.tests.cpp:: passed: std::strcmp(ss.c_str(), "world!") == 0 for: 0 == 0 String.tests.cpp:: passed: (char*)buffer1 != (char*)buffer2 for: "Hello" != "Hello" String.tests.cpp:: passed: left == right for: Hello == Hello String.tests.cpp:: passed: left != left.substr(0, 3) for: Hello != Hel String.tests.cpp:: passed: sr == "a standard string" for: a standard string == "a standard string" String.tests.cpp:: passed: sr.size() == stdStr.size() for: 17 == 17 String.tests.cpp:: passed: sr == "a standard string" for: a standard string == "a standard string" String.tests.cpp:: passed: sr.size() == stdStr.size() for: 17 == 17 String.tests.cpp:: passed: sr == "a standard string" for: a standard string == "a standard string" String.tests.cpp:: passed: sr.size() == stdStr.size() for: 17 == 17 String.tests.cpp:: passed: stdStr == "a stringref" for: "a stringref" == "a stringref" String.tests.cpp:: passed: stdStr.size() == sr.size() for: 11 == 11 String.tests.cpp:: passed: stdStr == "a stringref" for: "a stringref" == "a stringref" String.tests.cpp:: passed: stdStr.size() == sr.size() for: 11 == 11 String.tests.cpp:: passed: with 1 message: 'StringRef{}.size() == 0' String.tests.cpp:: passed: with 1 message: 'StringRef{ "abc", 3 }.size() == 3' String.tests.cpp:: passed: with 1 message: 'StringRef{ "abc", 3 }.isNullTerminated()' String.tests.cpp:: passed: with 1 message: 'StringRef{ "abc", 2 }.size() == 2' String.tests.cpp:: passed: with 1 message: '!(StringRef{ "abc", 2 }.isNullTerminated())' String.tests.cpp:: passed: with 1 message: '!(sr1.empty())' String.tests.cpp:: passed: with 1 message: 'sr1.size() == 3' String.tests.cpp:: passed: with 1 message: 'sr1.isNullTerminated()' String.tests.cpp:: passed: with 1 message: 'sr2.empty()' String.tests.cpp:: passed: with 1 message: 'sr2.size() == 0' String.tests.cpp:: passed: with 1 message: 'sr2.isNullTerminated()' ToStringChrono.tests.cpp:: passed: minute == seconds for: 1 m == 60 s ToStringChrono.tests.cpp:: passed: hour != seconds for: 1 h != 60 s ToStringChrono.tests.cpp:: passed: micro != milli for: 1 us != 1 ms ToStringChrono.tests.cpp:: passed: nano != micro for: 1 ns != 1 us ToStringChrono.tests.cpp:: passed: half_minute != femto_second for: 1 [30/1]s != 1 fs ToStringChrono.tests.cpp:: passed: pico_second != atto_second for: 1 ps != 1 as ToStringChrono.tests.cpp:: passed: now != later for: {iso8601-timestamp} != {iso8601-timestamp} Misc.tests.cpp:: failed: s1 == s2 for: "if ($b == 10) { $a = 20; }" == "if ($b == 10) { $a = 20; } " Tag.tests.cpp:: passed: what, Contains( "[@zzz]" ) for: "error: tag alias, '[@zzz]' already registered. First seen at: file:2 Redefined at: file:10" contains: "[@zzz]" Tag.tests.cpp:: passed: what, Contains( "file" ) for: "error: tag alias, '[@zzz]' already registered. First seen at: file:2 Redefined at: file:10" contains: "file" Tag.tests.cpp:: passed: what, Contains( "2" ) for: "error: tag alias, '[@zzz]' already registered. First seen at: file:2 Redefined at: file:10" contains: "2" Tag.tests.cpp:: passed: what, Contains( "10" ) for: "error: tag alias, '[@zzz]' already registered. First seen at: file:2 Redefined at: file:10" contains: "10" Tag.tests.cpp:: passed: registry.add( "[no ampersat]", "", Catch::SourceLineInfo( "file", 3 ) ) Tag.tests.cpp:: passed: registry.add( "[the @ is not at the start]", "", Catch::SourceLineInfo( "file", 3 ) ) Tag.tests.cpp:: passed: registry.add( "@no square bracket at start]", "", Catch::SourceLineInfo( "file", 3 ) ) Tag.tests.cpp:: passed: registry.add( "[@no square bracket at end", "", Catch::SourceLineInfo( "file", 3 ) ) Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1 == 1 Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1 == 1 Class.tests.cpp:: passed: Template_Fixture::m_a == 1 for: 1.0 == 1 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 1 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 4 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 1 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 4 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 4 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 1 > 0 Misc.tests.cpp:: passed: sizeof(TestType) > 0 for: 4 > 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 10 for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 10 for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 10 for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 10 for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.size() == 2 * V for: 12 == 12 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 12 >= 12 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 12 >= 12 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.size() == V for: 6 == 6 Misc.tests.cpp:: passed: v.capacity() >= V for: 6 >= 6 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.size() == 2 * V for: 8 == 8 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 8 >= 8 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 8 >= 8 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.size() == V for: 4 == 4 Misc.tests.cpp:: passed: v.capacity() >= V for: 4 >= 4 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 2 * V for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == V for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= V for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 Misc.tests.cpp:: passed: v.size() == 2 * V for: 30 == 30 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 30 >= 30 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= 2 * V for: 30 >= 30 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 Misc.tests.cpp:: passed: v.size() == V for: 15 == 15 Misc.tests.cpp:: passed: v.capacity() >= V for: 15 >= 15 VariadicMacros.tests.cpp:: passed: with 1 message: 'no assertions' Tricky.tests.cpp:: passed: 0x == bit30and31 for: 3221225472 (0x) == 3221225472 CmdLine.tests.cpp:: passed: Message.tests.cpp:: failed - but was ok: 1 == 2 Misc.tests.cpp:: passed: with 1 message: 'oops!' Exception.tests.cpp:: failed: unexpected exception with message: 'For some reason someone is throwing a string literal!' PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: testCase.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isComplete() for: true PartTracker.tests.cpp:: passed: s1.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: testCase.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isOpen() for: true PartTracker.tests.cpp:: passed: s1b.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: testCase.isComplete() for: true PartTracker.tests.cpp:: passed: testCase.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isComplete() for: true PartTracker.tests.cpp:: passed: s1.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: testCase.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isOpen() for: true PartTracker.tests.cpp:: passed: s1b.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: s2.isOpen() for: true PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: testCase.isComplete() for: true PartTracker.tests.cpp:: passed: testCase.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s2.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isOpen() for: true PartTracker.tests.cpp:: passed: s1b.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: s2b.isOpen() for: true PartTracker.tests.cpp:: passed: ctx.completedCycle() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: s2b.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase2.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s2.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isOpen() for: true PartTracker.tests.cpp:: passed: s1b.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: s2b.isOpen() for: true PartTracker.tests.cpp:: passed: ctx.completedCycle() == false for: false == false PartTracker.tests.cpp:: passed: ctx.completedCycle() for: true PartTracker.tests.cpp:: passed: s2b.isComplete() for: true PartTracker.tests.cpp:: passed: s2b.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase2.isSuccessfullyCompleted() == false for: false == false PartTracker.tests.cpp:: passed: testCase3.isOpen() for: true PartTracker.tests.cpp:: passed: s1c.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: s2c.isOpen() == false for: false == false PartTracker.tests.cpp:: passed: testCase3.isSuccessfullyCompleted() for: true PartTracker.tests.cpp:: passed: testCase.isOpen() for: true PartTracker.tests.cpp:: passed: s1.isOpen() for: true PartTracker.tests.cpp:: passed: s2.isOpen() for: true PartTracker.tests.cpp:: passed: s2.isComplete() for: true PartTracker.tests.cpp:: passed: s1.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: s1.isComplete() for: true PartTracker.tests.cpp:: passed: testCase.isComplete() == false for: false == false PartTracker.tests.cpp:: passed: testCase.isComplete() for: true StringManip.tests.cpp:: passed: trim(std::string(no_whitespace)) == no_whitespace for: "There is no extra whitespace here" == "There is no extra whitespace here" StringManip.tests.cpp:: passed: trim(std::string(leading_whitespace)) == no_whitespace for: "There is no extra whitespace here" == "There is no extra whitespace here" StringManip.tests.cpp:: passed: trim(std::string(trailing_whitespace)) == no_whitespace for: "There is no extra whitespace here" == "There is no extra whitespace here" StringManip.tests.cpp:: passed: trim(std::string(whitespace_at_both_ends)) == no_whitespace for: "There is no extra whitespace here" == "There is no extra whitespace here" StringManip.tests.cpp:: passed: trim(StringRef(no_whitespace)) == StringRef(no_whitespace) for: There is no extra whitespace here == There is no extra whitespace here StringManip.tests.cpp:: passed: trim(StringRef(leading_whitespace)) == StringRef(no_whitespace) for: There is no extra whitespace here == There is no extra whitespace here StringManip.tests.cpp:: passed: trim(StringRef(trailing_whitespace)) == StringRef(no_whitespace) for: There is no extra whitespace here == There is no extra whitespace here StringManip.tests.cpp:: passed: trim(StringRef(whitespace_at_both_ends)) == StringRef(no_whitespace) for: There is no extra whitespace here == There is no extra whitespace here Exception.tests.cpp:: failed: unexpected exception with message: '3.14' Approx.tests.cpp:: passed: d == approx( 1.23 ) for: 1.23 == Approx( 1.23 ) Approx.tests.cpp:: passed: d == approx( 1.22 ) for: 1.23 == Approx( 1.22 ) Approx.tests.cpp:: passed: d == approx( 1.24 ) for: 1.23 == Approx( 1.24 ) Approx.tests.cpp:: passed: d != approx( 1.25 ) for: 1.23 != Approx( 1.25 ) Approx.tests.cpp:: passed: approx( d ) == 1.23 for: Approx( 1.23 ) == 1.23 Approx.tests.cpp:: passed: approx( d ) == 1.22 for: Approx( 1.23 ) == 1.22 Approx.tests.cpp:: passed: approx( d ) == 1.24 for: Approx( 1.23 ) == 1.24 Approx.tests.cpp:: passed: approx( d ) != 1.25 for: Approx( 1.23 ) != 1.25 VariadicMacros.tests.cpp:: passed: with 1 message: 'no assertions' Matchers.tests.cpp:: passed: empty, Approx(empty) for: { } is approx: { } Matchers.tests.cpp:: passed: v1, Approx(v1) for: { 1.0, 2.0, 3.0 } is approx: { 1.0, 2.0, 3.0 } Matchers.tests.cpp:: passed: v1, !Approx(temp) for: { 1.0, 2.0, 3.0 } not is approx: { 1.0, 2.0, 3.0, 4.0 } Matchers.tests.cpp:: passed: v1, !Approx(v2) for: { 1.0, 2.0, 3.0 } not is approx: { 1.5, 2.5, 3.5 } Matchers.tests.cpp:: passed: v1, Approx(v2).margin(0.5) for: { 1.0, 2.0, 3.0 } is approx: { 1.5, 2.5, 3.5 } Matchers.tests.cpp:: passed: v1, Approx(v2).epsilon(0.5) for: { 1.0, 2.0, 3.0 } is approx: { 1.5, 2.5, 3.5 } Matchers.tests.cpp:: passed: v1, Approx(v2).epsilon(0.1).scale(500) for: { 1.0, 2.0, 3.0 } is approx: { 1.5, 2.5, 3.5 } Matchers.tests.cpp:: failed: empty, Approx(t1) for: { } is approx: { 1.0, 2.0 } Matchers.tests.cpp:: failed: v1, Approx(v2) for: { 2.0, 4.0, 6.0 } is approx: { 1.0, 3.0, 5.0 } Matchers.tests.cpp:: passed: v, VectorContains(1) for: { 1, 2, 3 } Contains: 1 Matchers.tests.cpp:: passed: v, VectorContains(2) for: { 1, 2, 3 } Contains: 2 Matchers.tests.cpp:: passed: v, Contains(v2) for: { 1, 2, 3 } Contains: { 1, 2 } Matchers.tests.cpp:: passed: v, Contains(v2) for: { 1, 2, 3 } Contains: { 1, 2, 3 } Matchers.tests.cpp:: passed: v, Contains(empty) for: { 1, 2, 3 } Contains: { } Matchers.tests.cpp:: passed: empty, Contains(empty) for: { } Contains: { } Matchers.tests.cpp:: passed: v, VectorContains(1) && VectorContains(2) for: { 1, 2, 3 } ( Contains: 1 and Contains: 2 ) Matchers.tests.cpp:: passed: v, Equals(v) for: { 1, 2, 3 } Equals: { 1, 2, 3 } Matchers.tests.cpp:: passed: empty, Equals(empty) for: { } Equals: { } Matchers.tests.cpp:: passed: v, Equals(v2) for: { 1, 2, 3 } Equals: { 1, 2, 3 } Matchers.tests.cpp:: passed: v, UnorderedEquals(v) for: { 1, 2, 3 } UnorderedEquals: { 1, 2, 3 } Matchers.tests.cpp:: passed: empty, UnorderedEquals(empty) for: { } UnorderedEquals: { } Matchers.tests.cpp:: passed: permuted, UnorderedEquals(v) for: { 1, 3, 2 } UnorderedEquals: { 1, 2, 3 } Matchers.tests.cpp:: passed: permuted, UnorderedEquals(v) for: { 2, 3, 1 } UnorderedEquals: { 1, 2, 3 } Matchers.tests.cpp:: failed: v, VectorContains(-1) for: { 1, 2, 3 } Contains: -1 Matchers.tests.cpp:: failed: empty, VectorContains(1) for: { } Contains: 1 Matchers.tests.cpp:: failed: empty, Contains(v) for: { } Contains: { 1, 2, 3 } Matchers.tests.cpp:: failed: v, Contains(v2) for: { 1, 2, 3 } Contains: { 1, 2, 4 } Matchers.tests.cpp:: failed: v, Equals(v2) for: { 1, 2, 3 } Equals: { 1, 2 } Matchers.tests.cpp:: failed: v2, Equals(v) for: { 1, 2 } Equals: { 1, 2, 3 } Matchers.tests.cpp:: failed: empty, Equals(v) for: { } Equals: { 1, 2, 3 } Matchers.tests.cpp:: failed: v, Equals(empty) for: { 1, 2, 3 } Equals: { } Matchers.tests.cpp:: failed: v, UnorderedEquals(empty) for: { 1, 2, 3 } UnorderedEquals: { } Matchers.tests.cpp:: failed: empty, UnorderedEquals(v) for: { } UnorderedEquals: { 1, 2, 3 } Matchers.tests.cpp:: failed: permuted, UnorderedEquals(v) for: { 1, 3 } UnorderedEquals: { 1, 2, 3 } Matchers.tests.cpp:: failed: permuted, UnorderedEquals(v) for: { 3, 1 } UnorderedEquals: { 1, 2, 3 } Exception.tests.cpp:: passed: thisThrows(), std::domain_error Exception.tests.cpp:: passed: thisDoesntThrow() Exception.tests.cpp:: passed: thisThrows() Exception.tests.cpp:: failed: unexpected exception with message: 'unexpected exception' Exception.tests.cpp:: failed: unexpected exception with message: 'expected exception'; expression was: thisThrows() == 0 Exception.tests.cpp:: failed: unexpected exception with message: 'expected exception'; expression was: thisThrows() == 0 Exception.tests.cpp:: failed: unexpected exception with message: 'expected exception'; expression was: thisThrows() == 0 Exception.tests.cpp:: failed: unexpected exception with message: 'unexpected exception' Tricky.tests.cpp:: warning: 'Uncomment the code in this test to check that it gives a sensible compiler error' Tricky.tests.cpp:: warning: 'Uncomment the code in this test to check that it gives a sensible compiler error' Tricky.tests.cpp:: passed: Tricky.tests.cpp:: passed: Tricky.tests.cpp:: passed: Tricky.tests.cpp:: passed: Xml.tests.cpp:: passed: encode( "normal string" ) == "normal string" for: "normal string" == "normal string" Xml.tests.cpp:: passed: encode( "" ) == "" for: "" == "" Xml.tests.cpp:: passed: encode( "smith & jones" ) == "smith & jones" for: "smith & jones" == "smith & jones" Xml.tests.cpp:: passed: encode( "smith < jones" ) == "smith < jones" for: "smith < jones" == "smith < jones" Xml.tests.cpp:: passed: encode( "smith > jones" ) == "smith > jones" for: "smith > jones" == "smith > jones" Xml.tests.cpp:: passed: encode( "smith ]]> jones" ) == "smith ]]> jones" for: "smith ]]> jones" == "smith ]]> jones" Xml.tests.cpp:: passed: encode( stringWithQuotes ) == stringWithQuotes for: "don't "quote" me on that" == "don't "quote" me on that" Xml.tests.cpp:: passed: encode( stringWithQuotes, Catch::XmlEncode::ForAttributes ) == "don't "quote" me on that" for: "don't "quote" me on that" == "don't "quote" me on that" Xml.tests.cpp:: passed: encode( "[\x01]" ) == "[\\x01]" for: "[\x01]" == "[\x01]" Xml.tests.cpp:: passed: encode( "[\x7F]" ) == "[\\x7F]" for: "[\x7F]" == "[\x7F]" ToStringVector.tests.cpp:: passed: Catch::Detail::stringify( empty ) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: Catch::Detail::stringify( oneValue ) == "{ 42 }" for: "{ 42 }" == "{ 42 }" ToStringVector.tests.cpp:: passed: Catch::Detail::stringify( twoValues ) == "{ 42, 250 }" for: "{ 42, 250 }" == "{ 42, 250 }" Misc.tests.cpp:: passed: x == 0 for: 0 == 0 Tricky.tests.cpp:: passed: obj.prop != 0 for: 0x != 0 Misc.tests.cpp:: passed: flag for: true Misc.tests.cpp:: passed: testCheckedElse( true ) for: true Misc.tests.cpp:: failed: flag for: false Misc.tests.cpp:: failed: testCheckedElse( false ) for: false Misc.tests.cpp:: passed: flag for: true Misc.tests.cpp:: passed: testCheckedIf( true ) for: true Misc.tests.cpp:: failed: flag for: false Misc.tests.cpp:: failed: testCheckedIf( false ) for: false Condition.tests.cpp:: passed: unsigned_char_var == 1 for: 1 == 1 Condition.tests.cpp:: passed: unsigned_short_var == 1 for: 1 == 1 Condition.tests.cpp:: passed: unsigned_int_var == 1 for: 1 == 1 Condition.tests.cpp:: passed: unsigned_long_var == 1 for: 1 == 1 Condition.tests.cpp:: passed: long_var == unsigned_char_var for: 1 == 1 Condition.tests.cpp:: passed: long_var == unsigned_short_var for: 1 == 1 Condition.tests.cpp:: passed: long_var == unsigned_int_var for: 1 == 1 Condition.tests.cpp:: passed: long_var == unsigned_long_var for: 1 == 1 Misc.tests.cpp:: passed: Misc.tests.cpp:: passed: Misc.tests.cpp:: passed: loose text artifact Message.tests.cpp:: failed: explicitly with 1 message: 'Previous info should not be seen' Message.tests.cpp:: failed: explicitly with 1 message: 'previous unscoped info SHOULD not be seen' Misc.tests.cpp:: passed: l == std::numeric_limits::max() for: 9223372036854775807 (0x) == 9223372036854775807 (0x) Misc.tests.cpp:: failed: b > a for: 0 > 1 Misc.tests.cpp:: failed: b > a for: 1 > 1 Misc.tests.cpp:: passed: b > a for: 2 > 1 Misc.tests.cpp:: passed: b > a for: 3 > 1 Misc.tests.cpp:: passed: b > a for: 4 > 1 Misc.tests.cpp:: passed: b > a for: 5 > 1 Misc.tests.cpp:: passed: b > a for: 6 > 1 Misc.tests.cpp:: passed: b > a for: 7 > 1 Misc.tests.cpp:: passed: b > a for: 8 > 1 Misc.tests.cpp:: passed: b > a for: 9 > 1 Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[0] (1) is even' Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[1] (1) is even' Misc.tests.cpp:: passed: ( fib[i] % 2 ) == 0 for: 0 == 0 with 1 message: 'Testing if fib[2] (2) is even' Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[3] (3) is even' Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[4] (5) is even' Misc.tests.cpp:: passed: ( fib[i] % 2 ) == 0 for: 0 == 0 with 1 message: 'Testing if fib[5] (8) is even' Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[6] (13) is even' Misc.tests.cpp:: failed: ( fib[i] % 2 ) == 0 for: 1 == 0 with 1 message: 'Testing if fib[7] (21) is even' Message.tests.cpp:: warning: 'info' with 2 messages: 'unscoped info' and 'and warn may mix' Message.tests.cpp:: warning: 'info' with 2 messages: 'unscoped info' and 'they are not cleared after warnings' Misc.tests.cpp:: failed: a == b for: 1 == 2 Misc.tests.cpp:: passed: a != b for: 1 != 2 Misc.tests.cpp:: passed: a < b for: 1 < 2 Misc.tests.cpp:: passed: a != b for: 1 != 2 Misc.tests.cpp:: passed: b != a for: 2 != 1 Misc.tests.cpp:: passed: a != b for: 1 != 2 Tricky.tests.cpp:: passed: s == "7" for: "7" == "7" Tricky.tests.cpp:: passed: ti == typeid(int) for: {?} == {?} Misc.tests.cpp:: passed: Message.tests.cpp:: passed: true with 1 message: 'this MAY be seen only for the FIRST assertion IF info is printed for passing assertions' Message.tests.cpp:: passed: true with 1 message: 'this MAY be seen only for the SECOND assertion IF info is printed for passing assertions' Message.tests.cpp:: failed: false with 1 message: 'this SHOULD be seen' Misc.tests.cpp:: passed: makeString( false ) != static_cast(0) for: "valid string" != {null string} Misc.tests.cpp:: passed: makeString( true ) == static_cast(0) for: {null string} == {null string} Tricky.tests.cpp:: passed: ptr.get() == 0 for: 0 == 0 ToStringPair.tests.cpp:: passed: ::Catch::Detail::stringify( pair ) == "{ { 42, \"Arthur\" }, { \"Ford\", 24 } }" for: "{ { 42, "Arthur" }, { "Ford", 24 } }" == "{ { 42, "Arthur" }, { "Ford", 24 } }" ToString.tests.cpp:: passed: parseEnums( "" ), Equals( std::vector{} ) for: { } Equals: { } ToString.tests.cpp:: passed: parseEnums( "ClassName::EnumName::Value1" ), Equals(std::vector{"Value1"} ) for: { Value1 } Equals: { Value1 } ToString.tests.cpp:: passed: parseEnums( "Value1" ), Equals( std::vector{"Value1"} ) for: { Value1 } Equals: { Value1 } ToString.tests.cpp:: passed: parseEnums( "EnumName::Value1" ), Equals(std::vector{"Value1"} ) for: { Value1 } Equals: { Value1 } ToString.tests.cpp:: passed: parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2" ), Equals( std::vector{"Value1", "Value2"} ) for: { Value1, Value2 } Equals: { Value1, Value2 } ToString.tests.cpp:: passed: parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2, ClassName::EnumName::Value3" ), Equals( std::vector{"Value1", "Value2", "Value3"} ) for: { Value1, Value2, Value3 } Equals: { Value1, Value2, Value3 } ToString.tests.cpp:: passed: parseEnums( "ClassName::EnumName::Value1,ClassName::EnumName::Value2 , ClassName::EnumName::Value3" ), Equals( std::vector{"Value1", "Value2", "Value3"} ) for: { Value1, Value2, Value3 } Equals: { Value1, Value2, Value3 } Tricky.tests.cpp:: passed: p == 0 for: 0 == 0 Message.tests.cpp:: passed: true with 1 message: 'this MAY be seen IF info is printed for passing assertions' Message.tests.cpp:: failed: false with 2 messages: 'this SHOULD be seen' and 'this SHOULD also be seen' Message.tests.cpp:: failed: false with 1 message: 'this SHOULD be seen only ONCE' Message.tests.cpp:: passed: true Message.tests.cpp:: passed: true with 1 message: 'this MAY also be seen only ONCE IF info is printed for passing assertions' Message.tests.cpp:: passed: true Misc.tests.cpp:: passed: a != b for: 1 != 2 Misc.tests.cpp:: passed: b != a for: 2 != 1 Misc.tests.cpp:: passed: a != b for: 1 != 2 StringManip.tests.cpp:: passed: Catch::replaceInPlace(letters, "b", "z") for: true StringManip.tests.cpp:: passed: letters == "azcdefcg" for: "azcdefcg" == "azcdefcg" StringManip.tests.cpp:: passed: Catch::replaceInPlace(letters, "c", "z") for: true StringManip.tests.cpp:: passed: letters == "abzdefzg" for: "abzdefzg" == "abzdefzg" StringManip.tests.cpp:: passed: Catch::replaceInPlace(letters, "a", "z") for: true StringManip.tests.cpp:: passed: letters == "zbcdefcg" for: "zbcdefcg" == "zbcdefcg" StringManip.tests.cpp:: passed: Catch::replaceInPlace(letters, "g", "z") for: true StringManip.tests.cpp:: passed: letters == "abcdefcz" for: "abcdefcz" == "abcdefcz" StringManip.tests.cpp:: passed: Catch::replaceInPlace(letters, letters, "replaced") for: true StringManip.tests.cpp:: passed: letters == "replaced" for: "replaced" == "replaced" StringManip.tests.cpp:: passed: !(Catch::replaceInPlace(letters, "x", "z")) for: !false StringManip.tests.cpp:: passed: letters == letters for: "abcdefcg" == "abcdefcg" StringManip.tests.cpp:: passed: Catch::replaceInPlace(s, "'", "|'") for: true StringManip.tests.cpp:: passed: s == "didn|'t" for: "didn|'t" == "didn|'t" Misc.tests.cpp:: failed: false with 1 message: '3' Message.tests.cpp:: failed: false with 2 messages: 'hi' and 'i := 7' Tag.tests.cpp:: passed: tags, Catch::VectorContains("magic-tag"_catch_sr) && Catch::VectorContains("."_catch_sr) for: { ., magic-tag } ( Contains: magic-tag and Contains: . ) StringManip.tests.cpp:: passed: splitStringRef("", ','), Equals(std::vector()) for: { } Equals: { } StringManip.tests.cpp:: passed: splitStringRef("abc", ','), Equals(std::vector{"abc"}) for: { abc } Equals: { abc } StringManip.tests.cpp:: passed: splitStringRef("abc,def", ','), Equals(std::vector{"abc", "def"}) for: { abc, def } Equals: { abc, def } Message.tests.cpp:: failed: false with 4 messages: 'Count 1 to 3...' and '1' and '2' and '3' Message.tests.cpp:: failed: false with 4 messages: 'Count 4 to 6...' and '4' and '5' and '6' ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( emptyMap ) == "{ }" for: "{ }" == "{ }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( map ) == "{ { \"one\", 1 } }" for: "{ { "one", 1 } }" == "{ { "one", 1 } }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( map ) == "{ { \"abc\", 1 }, { \"def\", 2 }, { \"ghi\", 3 } }" for: "{ { "abc", 1 }, { "def", 2 }, { "ghi", 3 } }" == "{ { "abc", 1 }, { "def", 2 }, { "ghi", 3 } }" ToStringPair.tests.cpp:: passed: ::Catch::Detail::stringify(value) == "{ 34, \"xyzzy\" }" for: "{ 34, "xyzzy" }" == "{ 34, "xyzzy" }" ToStringPair.tests.cpp:: passed: ::Catch::Detail::stringify( value ) == "{ 34, \"xyzzy\" }" for: "{ 34, "xyzzy" }" == "{ 34, "xyzzy" }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( emptySet ) == "{ }" for: "{ }" == "{ }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( set ) == "{ \"one\" }" for: "{ "one" }" == "{ "one" }" ToStringGeneral.tests.cpp:: passed: Catch::Detail::stringify( set ) == "{ \"abc\", \"def\", \"ghi\" }" for: "{ "abc", "def", "ghi" }" == "{ "abc", "def", "ghi" }" ToStringPair.tests.cpp:: passed: ::Catch::Detail::stringify( pr ) == "{ { \"green\", 55 } }" for: "{ { "green", 55 } }" == "{ { "green", 55 } }" Tricky.tests.cpp:: failed: std::string( "first" ) == "second" for: "first" == "second" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify(streamable_range{}) == "op<<(streamable_range)" for: "op<<(streamable_range)" == "op<<(streamable_range)" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify(stringmaker_range{}) == "stringmaker(streamable_range)" for: "stringmaker(streamable_range)" == "stringmaker(streamable_range)" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify(just_range{}) == "{ 1, 2, 3, 4 }" for: "{ 1, 2, 3, 4 }" == "{ 1, 2, 3, 4 }" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify(disabled_range{}) == "{?}" for: "{?}" == "{?}" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( item ) == "StringMaker" for: "StringMaker" == "StringMaker" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( item ) == "StringMaker" for: "StringMaker" == "StringMaker" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify(item) == "{?}" for: "{?}" == "{?}" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( item ) == "operator<<( has_operator )" for: "operator<<( has_operator )" == "operator<<( has_operator )" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( item ) == "operator<<( has_template_operator )" for: "operator<<( has_template_operator )" == "operator<<( has_template_operator )" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( v ) == "{ StringMaker }" for: "{ StringMaker }" == "{ StringMaker }" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( v ) == "{ StringMaker }" for: "{ StringMaker }" == "{ StringMaker }" ToStringWhich.tests.cpp:: passed: ::Catch::Detail::stringify( v ) == "{ operator<<( has_operator ) }" for: "{ operator<<( has_operator ) }" == "{ operator<<( has_operator ) }" Generators.tests.cpp:: passed: data.str.size() == data.len for: 3 == 3 Generators.tests.cpp:: passed: data.str.size() == data.len for: 3 == 3 Generators.tests.cpp:: passed: data.str.size() == data.len for: 5 == 5 Generators.tests.cpp:: passed: data.str.size() == data.len for: 4 == 4 Generators.tests.cpp:: passed: strlen(std::get<0>(data)) == static_cast(std::get<1>(data)) for: 5 == 5 Generators.tests.cpp:: passed: strlen(std::get<0>(data)) == static_cast(std::get<1>(data)) for: 6 == 6 Generators.tests.cpp:: passed: strlen(std::get<0>(data)) == static_cast(std::get<1>(data)) for: 5 == 5 Generators.tests.cpp:: passed: strlen(std::get<0>(data)) == static_cast(std::get<1>(data)) for: 6 == 6 Exception.tests.cpp:: failed: unexpected exception with message: 'Why would you throw a std::string?' Misc.tests.cpp:: passed: result == "\"wide load\"" for: ""wide load"" == ""wide load"" Misc.tests.cpp:: passed: result == "\"wide load\"" for: ""wide load"" == ""wide load"" Misc.tests.cpp:: passed: result == "\"wide load\"" for: ""wide load"" == ""wide load"" Misc.tests.cpp:: passed: result == "\"wide load\"" for: ""wide load"" == ""wide load"" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e0) == "E2/V0" for: "E2/V0" == "E2/V0" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e1) == "E2/V1" for: "E2/V1" == "E2/V1" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e3) == "Unknown enum value 10" for: "Unknown enum value 10" == "Unknown enum value 10" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e0) == "0" for: "0" == "0" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e1) == "1" for: "1" == "1" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e0) == "E2{0}" for: "E2{0}" == "E2{0}" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e1) == "E2{1}" for: "E2{1}" == "E2{1}" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e0) == "0" for: "0" == "0" EnumToString.tests.cpp:: passed: ::Catch::Detail::stringify(e1) == "1" for: "1" == "1" ToStringTuple.tests.cpp:: passed: "{ }" == ::Catch::Detail::stringify(type{}) for: "{ }" == "{ }" ToStringTuple.tests.cpp:: passed: "{ }" == ::Catch::Detail::stringify(value) for: "{ }" == "{ }" ToStringTuple.tests.cpp:: passed: "1.2f" == ::Catch::Detail::stringify(float(1.2)) for: "1.2f" == "1.2f" ToStringTuple.tests.cpp:: passed: "{ 1.2f, 0 }" == ::Catch::Detail::stringify(type{1.2f,0}) for: "{ 1.2f, 0 }" == "{ 1.2f, 0 }" ToStringTuple.tests.cpp:: passed: "{ 0 }" == ::Catch::Detail::stringify(type{0}) for: "{ 0 }" == "{ 0 }" ToStringTuple.tests.cpp:: passed: "{ 0, 42, \"Catch me\" }" == ::Catch::Detail::stringify(value) for: "{ 0, 42, "Catch me" }" == "{ 0, 42, "Catch me" }" ToStringTuple.tests.cpp:: passed: "{ \"hello\", \"world\" }" == ::Catch::Detail::stringify(type{"hello","world"}) for: "{ "hello", "world" }" == "{ "hello", "world" }" ToStringTuple.tests.cpp:: passed: "{ { 42 }, { }, 1.2f }" == ::Catch::Detail::stringify(value) for: "{ { 42 }, { }, 1.2f }" == "{ { 42 }, { }, 1.2f }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(v) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(v) == "{ { \"hello\" }, { \"world\" } }" for: "{ { "hello" }, { "world" } }" == "{ { "hello" }, { "world" } }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(bools) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(bools) == "{ true }" for: "{ true }" == "{ true }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(bools) == "{ true, false }" for: "{ true, false }" == "{ true, false }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ 42 }" for: "{ 42 }" == "{ 42 }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ 42, 250 }" for: "{ 42, 250 }" == "{ 42, 250 }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ 42 }" for: "{ 42 }" == "{ 42 }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ 42, 250 }" for: "{ 42, 250 }" == "{ 42, 250 }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ }" for: "{ }" == "{ }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ \"hello\" }" for: "{ "hello" }" == "{ "hello" }" ToStringVector.tests.cpp:: passed: ::Catch::Detail::stringify(vv) == "{ \"hello\", \"world\" }" for: "{ "hello", "world" }" == "{ "hello", "world" }" Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 10 for: 10 == 10 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.capacity() == 0 for: 0 == 0 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 10 for: 10 >= 10 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: v.size() == 5 for: 5 == 5 Misc.tests.cpp:: passed: v.capacity() >= 5 for: 5 >= 5 Misc.tests.cpp:: passed: Misc.tests.cpp:: passed: Failed 86 test cases, failed 148 assertions.