2010-11-09 18:24:00 -05: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 03:32:40 -04:00
|
|
|
#include "catch.hpp"
|
2010-11-09 18:24:00 -05:00
|
|
|
|
2011-01-14 03:47:43 -05:00
|
|
|
TEST_CASE( "./succeeding/message", "INFO and WARN do not abort tests" )
|
2010-11-09 18:24:00 -05:00
|
|
|
{
|
2010-12-27 17:05:13 -05:00
|
|
|
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
|
2010-11-09 18:24:00 -05:00
|
|
|
}
|
2012-11-21 03:49:20 -05:00
|
|
|
TEST_CASE( "./succeeding/succeed", "SUCCEED counts as a test pass" )
|
|
|
|
{
|
|
|
|
SUCCEED( "this is a " << "success" );
|
|
|
|
}
|
2010-11-09 18:24:00 -05:00
|
|
|
|
2011-01-14 03:47:43 -05:00
|
|
|
TEST_CASE( "./failing/message/info/1", "INFO gets logged on failure" )
|
2010-12-27 17:05:13 -05:00
|
|
|
{
|
|
|
|
INFO( "this message should be logged" );
|
2010-12-27 17:18:33 -05:00
|
|
|
INFO( "so should this" );
|
2010-12-27 17:05:13 -05:00
|
|
|
int a = 2;
|
|
|
|
REQUIRE( a == 1 );
|
|
|
|
}
|
|
|
|
|
2011-01-14 03:47:43 -05:00
|
|
|
TEST_CASE( "./mixed/message/info/2", "INFO gets logged on failure" )
|
2010-12-27 17:05:13 -05:00
|
|
|
{
|
2013-02-02 15:46:55 -05:00
|
|
|
INFO( "this message should not be logged" );
|
2010-12-27 17:05:13 -05:00
|
|
|
int a = 2;
|
2010-12-27 17:18:33 -05:00
|
|
|
CHECK( a == 2 );
|
2010-12-27 17:05:13 -05:00
|
|
|
|
2013-02-02 15:46:55 -05:00
|
|
|
INFO( "this message should be logged" );
|
2010-12-27 17:05:13 -05:00
|
|
|
|
2010-12-27 17:18:33 -05:00
|
|
|
CHECK( a == 1 );
|
|
|
|
|
|
|
|
INFO( "and this, but later" );
|
|
|
|
|
|
|
|
CHECK( a == 0 );
|
|
|
|
|
|
|
|
INFO( "but not this" );
|
|
|
|
|
|
|
|
CHECK( a == 2 );
|
2010-12-27 17:05:13 -05:00
|
|
|
}
|
|
|
|
|
2011-01-14 03:47:43 -05:00
|
|
|
TEST_CASE( "./failing/message/fail", "FAIL aborts the test" )
|
2010-11-09 18:24:00 -05:00
|
|
|
{
|
2012-11-06 02:52:28 -05:00
|
|
|
if( true )
|
|
|
|
FAIL( "This is a " << "failure" ); // This should output the message and abort
|
2011-02-16 14:02:09 -05:00
|
|
|
}
|
2011-12-28 05:23:32 -05:00
|
|
|
|
|
|
|
TEST_CASE( "./failing/message/sections", "Output from all sections is reported" )
|
|
|
|
{
|
|
|
|
SECTION( "one", "" )
|
|
|
|
{
|
|
|
|
FAIL( "Message from section one" );
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION( "two", "" )
|
|
|
|
{
|
|
|
|
FAIL( "Message from section two" );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE( "./succeeding/message/sections/stdout", "Output from all sections is reported" )
|
|
|
|
{
|
|
|
|
SECTION( "one", "" )
|
|
|
|
{
|
|
|
|
std::cout << "Message from section one" << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION( "two", "" )
|
|
|
|
{
|
|
|
|
std::cout << "Message from section two" << std::endl;
|
|
|
|
}
|
|
|
|
}
|
2012-05-22 17:21:17 -04:00
|
|
|
|
|
|
|
TEST_CASE( "./mixed/message/scoped", "" )
|
|
|
|
{
|
|
|
|
for( int i=0; i<100; i++ )
|
|
|
|
{
|
2012-10-04 03:14:48 -04:00
|
|
|
SCOPED_INFO( "current counter " << i );
|
|
|
|
SCOPED_CAPTURE( i );
|
|
|
|
REQUIRE( i < 10 );
|
2012-05-22 17:21:17 -04:00
|
|
|
}
|
|
|
|
}
|
2012-11-13 04:44:52 -05:00
|
|
|
|
|
|
|
TEST_CASE( "./succeeding/nofail", "The NO_FAIL macro reports a failure but does not fail the test" )
|
|
|
|
{
|
|
|
|
CHECK_NOFAIL( 1 == 2 );
|
|
|
|
}
|
2013-02-03 19:05:16 -05:00
|
|
|
|
|
|
|
TEST_CASE( "just info", "[info][isolated info]" )
|
|
|
|
{
|
|
|
|
INFO( "this should never be seen" );
|
|
|
|
}
|
|
|
|
TEST_CASE( "just failure", "[fail][isolated info]" )
|
|
|
|
{
|
|
|
|
FAIL( "Previous info should not be seen" );
|
|
|
|
}
|