| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 | // 207-Rpt-TeamCityReporter.cpp// Catch has built-in and external reporters:// Built-in:// - compact// - console// - junit// - xml// External:// - automake// - tap// - teamcity (this example)// main() and reporter code provided in 200-Rpt-CatchMain.cpp#include <catch2/catch.hpp>#ifdef _MSC_VER# pragma warning (disable : 4702) // Disable warning: unreachable code#endifTEST_CASE( "TeamCity passes unconditionally succeeding assertion", "[teamcity]" ) {    SUCCEED();}TEST_CASE( "TeamCity reports unconditionally failing assertion", "[teamcity]" ) {    FAIL();}TEST_CASE( "TeamCity reports failing check", "[teamcity]" ) {    REQUIRE( 3 == 7 );}TEST_CASE( "TeamCity reports failing check-false", "[teamcity]" ) {    REQUIRE_FALSE( 3 == 3 );}TEST_CASE( "TeamCity reports failing check-that", "[teamcity]" ) {    using namespace Catch;    REQUIRE_THAT( "hello", Contains( "world" ) );}TEST_CASE( "TeamCity reports unexpected exception", "[teamcity]" ) {    REQUIRE( (throw std::runtime_error("surprise!"), true) );}TEST_CASE( "TeamCity reports undesired exception", "[teamcity]" ) {    REQUIRE_NOTHROW( (throw std::runtime_error("surprise!"), true) );}TEST_CASE( "TeamCity reports missing expected exception", "[teamcity]" ) {    REQUIRE_THROWS( true );}TEST_CASE( "TeamCity reports missing specific expected exception", "[teamcity]" ) {    REQUIRE_THROWS_AS( throw std::bad_alloc(), std::runtime_error );}TEST_CASE( "TeamCity reports unexpected message in expected exception", "[teamcity]" ) {    using namespace Catch;    CHECK_THROWS_WITH( throw std::runtime_error("hello"), "world" );    CHECK_THROWS_WITH( throw std::runtime_error("hello"), Contains("world") );}struct MyException: public std::runtime_error{    MyException( char const * text )    : std::runtime_error( text ) {}        ~MyException() override;};// prevent -Wweak-vtables:MyException::~MyException() = default;struct MyExceptionMatcher : Catch::MatcherBase< std::runtime_error >{    std::string m_text;    MyExceptionMatcher( char const * text )    : m_text( text )    {}    ~MyExceptionMatcher() override;        bool match( std::runtime_error const & arg ) const override    {         return m_text == arg.what() ;     }        std::string describe() const override     {         return "it's me";    }};// prevent -Wweak-vtables:MyExceptionMatcher::~MyExceptionMatcher() = default;TEST_CASE( "TeamCity failing check-throws-matches", "[teamcity]" ) {    CHECK_THROWS_MATCHES( throw MyException("hello"), MyException, MyExceptionMatcher("world") );}// [!throws] - lets Catch know that this test is likely to throw an exception even if successful. // This causes the test to be excluded when running with -e or --nothrow.// No special effects for the reporter.TEST_CASE( "TeamCity throwing exception with tag [!throws]", "[teamcity][!throws]" ) {    REQUIRE_THROWS( throw std::runtime_error("unsurprisingly") );}// [!mayfail] - doesn't fail the test if any given assertion fails (but still reports it). This can be useful to flag a work-in-progress, or a known issue that you don't want to immediately fix but still want to track in your tests.TEST_CASE( "TeamCity failing assertion with tag [!mayfail]", "[teamcity][!mayfail] " ) {    REQUIRE( 3 == 7 );  // doesn't fail test case this time, reports: testIgnored    REQUIRE( 3 == 3 );}// [!shouldfail] - like [!mayfail] but fails the test if it passes. // This can be useful if you want to be notified of accidental, or third-party, fixes.TEST_CASE( "TeamCity succeeding assertion with tag [!shouldfail]", "[teamcity][!shouldfail]" ) {    SUCCEED( "Marked [!shouldfail]" );}// Compile & run:// - g++ -std=c++11 -Wall -I$(CATCH_ROOT) -DCATCH_EXAMPLE_RPT_1=\"include/reporters/catch_reporter_teamcity.hpp\" -o 200-Rpt-CatchMainTeamCity.o -c 200-Rpt-CatchMain.cpp// - g++ -std=c++11 -Wall -I$(CATCH_ROOT) -o 207-Rpt-TeamCityReporter 207-Rpt-TeamCityReporter.cpp 200-Rpt-CatchMainTeamCity.o && 207-Rpt-TeamCityReporter --list-reporters//// - cl -EHsc -I%CATCH_ROOT% -DCATCH_EXAMPLE_RPT_1=\"include/reporters/catch_reporter_teamcity.hpp\" -Fo200-Rpt-CatchMainTeamCity.obj -c 200-Rpt-CatchMain.cpp// - cl -EHsc -I%CATCH_ROOT% 207-Rpt-TeamCityReporter.cpp 200-Rpt-CatchMainTeamCity.o && 207-Rpt-TeamCityReporter --list-reporters// Compilation output (--list-reporters):// Available reporters://   compact:   Reports test results on a single line, suitable for IDEs//   console:   Reports test results as plain lines of text//   junit:     Reports test results in an XML format that looks like Ant's//                junitreport target//   teamcity:  Reports test results as TeamCity service messages//   xml:       Reports test results as an XML document// Expected output (abbreviated and broken into shorter lines)://// prompt> 207-Rpt-TeamCityReporter.exe --reporter teamcity// ##teamcity[testSuiteStarted name='207-Rpt-TeamCityReporter.exe']// ##teamcity[testStarted name='TeamCity passes unconditionally succeeding assertion']// ##teamcity[testFinished name='TeamCity passes unconditionally succeeding assertion' duration='1']// ##teamcity[testStarted name='TeamCity reports unconditionally failing assertion']// ##teamcity[testFailed name='TeamCity reports unconditionally failing assertion' /// message='.../examples/207-Rpt-TeamCityReporter.cpp:23|n/// ...............................................................................|n|n/// .../examples/207-Rpt-TeamCityReporter.cpp:25|nexplicit failure']// ##teamcity[testFinished name='TeamCity reports unconditionally failing assertion' duration='3']// ...
 |