catch2/projects/SelfTest/MessageTests.cpp

126 lines
3.2 KiB
C++
Raw Normal View History

2010-11-10 00:24:00 +01:00
/*
* Created by Phil on 09/11/2010.
* Copyright 2010 Two Blue Cubes Ltd. All rights reserved.
*
* Distributed under the Boost Software License, Version 1.0. (See accompanying
* file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
*/
2011-04-26 09:32:40 +02:00
#include "catch.hpp"
2010-11-10 00:24:00 +01:00
2013-12-09 17:01:23 +01:00
namespace MessageTests
2010-11-10 00:24:00 +01:00
{
2013-12-09 17:01:23 +01:00
TEST_CASE( "INFO and WARN do not abort tests", "[messages]" )
{
INFO( "this is a " << "message" ); // This should output the message if a failure occurs
WARN( "this is a " << "warning" ); // This should always output the message but then continue
}
TEST_CASE( "SUCCEED counts as a test pass", "[messages]" )
{
SUCCEED( "this is a " << "success" );
}
2010-12-27 23:05:13 +01:00
2013-12-09 17:01:23 +01:00
TEST_CASE( "INFO gets logged on failure", "[failing][messages][.]" )
{
INFO( "this message should be logged" );
INFO( "so should this" );
int a = 2;
REQUIRE( a == 1 );
}
2013-12-09 17:01:23 +01:00
TEST_CASE( "INFO gets logged on failure, even if captured before successful assertions", "[failing][messages][.]" )
{
INFO( "this message may be logged later" );
int a = 2;
CHECK( a == 2 );
2013-12-09 17:01:23 +01:00
INFO( "this message should be logged" );
2013-12-09 17:01:23 +01:00
CHECK( a == 1 );
2013-12-09 17:01:23 +01:00
INFO( "and this, but later" );
2013-12-09 17:01:23 +01:00
CHECK( a == 0 );
2013-12-09 17:01:23 +01:00
INFO( "but not this" );
2010-12-27 23:05:13 +01:00
2013-12-09 17:01:23 +01:00
CHECK( a == 2 );
}
2013-12-09 17:01:23 +01:00
TEST_CASE( "FAIL aborts the test", "[failing][messages][.]" )
{
2013-12-16 12:31:14 +01:00
FAIL( "This is a " << "failure" ); // This should output the message and abort
}
2013-12-16 12:31:14 +01:00
#ifdef CATCH_CONFIG_VARIADIC_MACROS
TEST_CASE( "FAIL does not require an argument", "[failing][messages][.]" )
{
2013-12-16 12:31:14 +01:00
FAIL();
}
2013-12-16 12:31:14 +01:00
TEST_CASE( "SUCCESS does not require an argument", "[messages][.]" )
{
SUCCEED();
}
#endif
2013-12-09 17:01:23 +01:00
TEST_CASE( "Output from all sections is reported", "[failing][messages][.]" )
{
2013-12-09 17:01:23 +01:00
SECTION( "one", "" )
{
FAIL( "Message from section one" );
}
SECTION( "two", "" )
{
FAIL( "Message from section two" );
}
}
2013-12-09 17:01:23 +01:00
TEST_CASE( "Standard output from all sections is reported", "[messages]" )
{
2013-12-09 17:01:23 +01:00
SECTION( "one", "" )
{
std::cout << "Message from section one" << std::endl;
}
2013-12-09 17:01:23 +01:00
SECTION( "two", "" )
{
std::cout << "Message from section two" << std::endl;
}
}
2013-12-09 17:01:23 +01:00
TEST_CASE( "SCOPED_INFO is reset for each loop", "[messages][failing][.]" )
{
2013-12-09 17:01:23 +01:00
for( int i=0; i<100; i++ )
{
SCOPED_INFO( "current counter " << i );
SCOPED_CAPTURE( i );
REQUIRE( i < 10 );
}
}
2012-11-13 10:44:52 +01:00
2013-12-09 17:01:23 +01:00
TEST_CASE( "The NO_FAIL macro reports a failure but does not fail the test", "[messages]" )
{
2013-12-09 17:01:23 +01:00
CHECK_NOFAIL( 1 == 2 );
}
2013-12-09 17:01:23 +01:00
TEST_CASE( "just info", "[info][isolated info][messages]" )
{
2013-12-09 17:01:23 +01:00
INFO( "this should never be seen" );
}
TEST_CASE( "just failure", "[fail][isolated info][.][messages]" )
{
FAIL( "Previous info should not be seen" );
}
2013-12-09 16:14:47 +01:00
2013-12-09 17:01:23 +01:00
TEST_CASE( "sends information to INFO", "[.][failing]" )
{
INFO( "hi" );
int i = 7;
CAPTURE( i );
REQUIRE( false );
}
2013-12-09 16:14:47 +01:00
}