mirror of
https://github.com/catchorg/Catch2.git
synced 2025-01-11 04:13:29 +01:00
Big assertion capture refactoring.
- moved as much logic out of the macros as possible - moved most logic into new ResultBuilder class, which wraps ExpressionResultBuilder (may take it over next), subsumes ResultAction and also takes place of ExpressionDecomposer. This introduces many SRP violations - but all in the name of minimising macro logic!
This commit is contained in:
parent
14796814b8
commit
9438a03d5b
@ -63,7 +63,7 @@
|
|||||||
#define CATCH_REQUIRE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal, "CATCH_REQUIRE" )
|
#define CATCH_REQUIRE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal, "CATCH_REQUIRE" )
|
||||||
#define CATCH_REQUIRE_FALSE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal | Catch::ResultDisposition::NegateResult, "CATCH_REQUIRE_FALSE" )
|
#define CATCH_REQUIRE_FALSE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal | Catch::ResultDisposition::NegateResult, "CATCH_REQUIRE_FALSE" )
|
||||||
|
|
||||||
#define CATCH_REQUIRE_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, ..., Catch::ResultDisposition::Normal, "CATCH_REQUIRE_THROWS" )
|
#define CATCH_REQUIRE_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, Catch::ResultDisposition::Normal, "CATCH_REQUIRE_THROWS" )
|
||||||
#define CATCH_REQUIRE_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::Normal, "CATCH_REQUIRE_THROWS_AS" )
|
#define CATCH_REQUIRE_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::Normal, "CATCH_REQUIRE_THROWS_AS" )
|
||||||
#define CATCH_REQUIRE_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::Normal, "CATCH_REQUIRE_NOTHROW" )
|
#define CATCH_REQUIRE_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::Normal, "CATCH_REQUIRE_NOTHROW" )
|
||||||
|
|
||||||
@ -73,7 +73,7 @@
|
|||||||
#define CATCH_CHECKED_ELSE( expr ) INTERNAL_CATCH_ELSE( expr, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECKED_ELSE" )
|
#define CATCH_CHECKED_ELSE( expr ) INTERNAL_CATCH_ELSE( expr, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECKED_ELSE" )
|
||||||
#define CATCH_CHECK_NOFAIL( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::ContinueOnFailure | Catch::ResultDisposition::SuppressFail, "CATCH_CHECK_NOFAIL" )
|
#define CATCH_CHECK_NOFAIL( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::ContinueOnFailure | Catch::ResultDisposition::SuppressFail, "CATCH_CHECK_NOFAIL" )
|
||||||
|
|
||||||
#define CATCH_CHECK_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, ..., Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_THROWS" )
|
#define CATCH_CHECK_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_THROWS" )
|
||||||
#define CATCH_CHECK_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_THROWS_AS" )
|
#define CATCH_CHECK_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_THROWS_AS" )
|
||||||
#define CATCH_CHECK_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_NOTHROW" )
|
#define CATCH_CHECK_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::ContinueOnFailure, "CATCH_CHECK_NOTHROW" )
|
||||||
|
|
||||||
@ -126,7 +126,7 @@
|
|||||||
#define REQUIRE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal, "REQUIRE" )
|
#define REQUIRE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal, "REQUIRE" )
|
||||||
#define REQUIRE_FALSE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal | Catch::ResultDisposition::NegateResult, "REQUIRE_FALSE" )
|
#define REQUIRE_FALSE( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::Normal | Catch::ResultDisposition::NegateResult, "REQUIRE_FALSE" )
|
||||||
|
|
||||||
#define REQUIRE_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, ..., Catch::ResultDisposition::Normal, "REQUIRE_THROWS" )
|
#define REQUIRE_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, Catch::ResultDisposition::Normal, "REQUIRE_THROWS" )
|
||||||
#define REQUIRE_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::Normal, "REQUIRE_THROWS_AS" )
|
#define REQUIRE_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::Normal, "REQUIRE_THROWS_AS" )
|
||||||
#define REQUIRE_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::Normal, "REQUIRE_NOTHROW" )
|
#define REQUIRE_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::Normal, "REQUIRE_NOTHROW" )
|
||||||
|
|
||||||
@ -136,7 +136,7 @@
|
|||||||
#define CHECKED_ELSE( expr ) INTERNAL_CATCH_ELSE( expr, Catch::ResultDisposition::ContinueOnFailure, "CHECKED_ELSE" )
|
#define CHECKED_ELSE( expr ) INTERNAL_CATCH_ELSE( expr, Catch::ResultDisposition::ContinueOnFailure, "CHECKED_ELSE" )
|
||||||
#define CHECK_NOFAIL( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::ContinueOnFailure | Catch::ResultDisposition::SuppressFail, "CHECK_NOFAIL" )
|
#define CHECK_NOFAIL( expr ) INTERNAL_CATCH_TEST( expr, Catch::ResultDisposition::ContinueOnFailure | Catch::ResultDisposition::SuppressFail, "CHECK_NOFAIL" )
|
||||||
|
|
||||||
#define CHECK_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, ..., Catch::ResultDisposition::ContinueOnFailure, "CHECK_THROWS" )
|
#define CHECK_THROWS( expr ) INTERNAL_CATCH_THROWS( expr, Catch::ResultDisposition::ContinueOnFailure, "CHECK_THROWS" )
|
||||||
#define CHECK_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::ContinueOnFailure, "CHECK_THROWS_AS" )
|
#define CHECK_THROWS_AS( expr, exceptionType ) INTERNAL_CATCH_THROWS_AS( expr, exceptionType, Catch::ResultDisposition::ContinueOnFailure, "CHECK_THROWS_AS" )
|
||||||
#define CHECK_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::ContinueOnFailure, "CHECK_NOTHROW" )
|
#define CHECK_NOTHROW( expr ) INTERNAL_CATCH_NO_THROW( expr, Catch::ResultDisposition::ContinueOnFailure, "CHECK_NOTHROW" )
|
||||||
|
|
||||||
|
@ -8,85 +8,38 @@
|
|||||||
#ifndef TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
#ifndef TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
||||||
#define TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
#define TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
||||||
|
|
||||||
#include "catch_expression_decomposer.hpp"
|
#include "catch_result_builder.h"
|
||||||
#include "catch_expressionresult_builder.h"
|
|
||||||
#include "catch_message.h"
|
#include "catch_message.h"
|
||||||
#include "catch_interfaces_capture.h"
|
#include "catch_interfaces_capture.h"
|
||||||
#include "catch_debugger.h"
|
#include "catch_debugger.h"
|
||||||
#include "catch_context.h"
|
|
||||||
#include "catch_common.h"
|
#include "catch_common.h"
|
||||||
#include "catch_tostring.h"
|
#include "catch_tostring.h"
|
||||||
#include "catch_interfaces_registry_hub.h"
|
#include "catch_interfaces_runner.h"
|
||||||
#include "catch_interfaces_config.h"
|
|
||||||
#include "internal/catch_compiler_capabilities.h"
|
#include "internal/catch_compiler_capabilities.h"
|
||||||
|
|
||||||
#include <ostream>
|
|
||||||
|
|
||||||
namespace Catch {
|
|
||||||
|
|
||||||
inline IResultCapture& getResultCapture() {
|
|
||||||
if( IResultCapture* capture = getCurrentContext().getResultCapture() )
|
|
||||||
return *capture;
|
|
||||||
else
|
|
||||||
throw std::logic_error( "No result capture instance" );
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename MatcherT>
|
|
||||||
ExpressionResultBuilder expressionResultBuilderFromMatcher( MatcherT const& matcher,
|
|
||||||
std::string const& matcherCallAsString ) {
|
|
||||||
std::string matcherAsString = matcher.toString();
|
|
||||||
if( matcherAsString == "{?}" )
|
|
||||||
matcherAsString = matcherCallAsString;
|
|
||||||
return ExpressionResultBuilder()
|
|
||||||
.setRhs( matcherAsString )
|
|
||||||
.setOp( "matches" );
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename MatcherT, typename ArgT>
|
|
||||||
ExpressionResultBuilder expressionResultBuilderFromMatcher( MatcherT const& matcher,
|
|
||||||
ArgT const& arg,
|
|
||||||
std::string const& matcherCallAsString ) {
|
|
||||||
return expressionResultBuilderFromMatcher( matcher, matcherCallAsString )
|
|
||||||
.setLhs( Catch::toString( arg ) )
|
|
||||||
.setResultType( matcher.match( arg ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename MatcherT, typename ArgT>
|
|
||||||
ExpressionResultBuilder expressionResultBuilderFromMatcher( MatcherT const& matcher,
|
|
||||||
ArgT* arg,
|
|
||||||
std::string const& matcherCallAsString ) {
|
|
||||||
return expressionResultBuilderFromMatcher( matcher, matcherCallAsString )
|
|
||||||
.setLhs( Catch::toString( arg ) )
|
|
||||||
.setResultType( matcher.match( arg ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
struct TestFailureException{};
|
|
||||||
|
|
||||||
} // end namespace Catch
|
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_ACCEPT_EXPR( evaluatedExpr, resultDisposition, originalExpr ) \
|
// In the event of a failure works out if the debugger needs to be invoked
|
||||||
if( Catch::ResultAction::Value internal_catch_action = Catch::getResultCapture().acceptExpression( evaluatedExpr, __assertionInfo ) ) { \
|
// and/or an exception thrown and takes appropriate action.
|
||||||
if( internal_catch_action & Catch::ResultAction::Debug ) CATCH_BREAK_INTO_DEBUGGER(); \
|
// This needs to be done as a macro so the debugger will stop in the user
|
||||||
if( internal_catch_action & Catch::ResultAction::Abort ) throw Catch::TestFailureException(); \
|
// source code rather than in Catch library code
|
||||||
if( !Catch::shouldContinueOnFailure( resultDisposition ) ) throw Catch::TestFailureException(); \
|
#define INTERNAL_CATCH_REACT( resultBuilder ) \
|
||||||
Catch::isTrue( false && originalExpr ); \
|
if( resultBuilder.shouldDebugBreak() ) CATCH_BREAK_INTO_DEBUGGER(); \
|
||||||
}
|
resultBuilder.react();
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_TEST( expr, resultDisposition, macroName ) \
|
#define INTERNAL_CATCH_TEST( expr, resultDisposition, macroName ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
||||||
try { \
|
try { \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( ( Catch::ExpressionDecomposer()->*expr ).endExpression( resultDisposition ), resultDisposition, expr ); \
|
( __catchResult->*expr ).endExpression(); \
|
||||||
} catch( Catch::TestFailureException& ) { \
|
|
||||||
throw; \
|
|
||||||
} catch( ... ) { \
|
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( Catch::ResultWas::ThrewException ) << Catch::translateActiveException(), \
|
|
||||||
Catch::ResultDisposition::Normal, expr ); \
|
|
||||||
} \
|
} \
|
||||||
} while( Catch::isTrue( false ) )
|
catch( ... ) { \
|
||||||
|
__catchResult.useActiveException( Catch::ResultDisposition::Normal ); \
|
||||||
|
} \
|
||||||
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() && (expr) ) // expr here is never evaluated at runtime but it forces the compiler to give it a look
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_IF( expr, resultDisposition, macroName ) \
|
#define INTERNAL_CATCH_IF( expr, resultDisposition, macroName ) \
|
||||||
@ -101,82 +54,90 @@ struct TestFailureException{};
|
|||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_NO_THROW( expr, resultDisposition, macroName ) \
|
#define INTERNAL_CATCH_NO_THROW( expr, resultDisposition, macroName ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
||||||
try { \
|
try { \
|
||||||
expr; \
|
expr; \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( Catch::ResultWas::Ok ), resultDisposition, false ); \
|
__catchResult.captureResult( Catch::ResultWas::Ok ); \
|
||||||
} \
|
} \
|
||||||
catch( ... ) { \
|
catch( ... ) { \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( Catch::ResultWas::ThrewException ) << Catch::translateActiveException(), resultDisposition, false ); \
|
__catchResult.useActiveException( resultDisposition ); \
|
||||||
} \
|
} \
|
||||||
} while( Catch::isTrue( false ) )
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_THROWS_IMPL( expr, exceptionType, resultDisposition ) \
|
#define INTERNAL_CATCH_THROWS( expr, resultDisposition, macroName ) \
|
||||||
try { \
|
|
||||||
if( Catch::getCurrentContext().getConfig()->allowThrows() ) { \
|
|
||||||
expr; \
|
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( Catch::ResultWas::DidntThrowException ), resultDisposition, false ); \
|
|
||||||
} \
|
|
||||||
} \
|
|
||||||
catch( Catch::TestFailureException& ) { \
|
|
||||||
throw; \
|
|
||||||
} \
|
|
||||||
catch( exceptionType ) { \
|
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( Catch::ResultWas::Ok ), resultDisposition, false ); \
|
|
||||||
}
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
|
||||||
#define INTERNAL_CATCH_THROWS( expr, exceptionType, resultDisposition, macroName ) \
|
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
||||||
INTERNAL_CATCH_THROWS_IMPL( expr, exceptionType, resultDisposition ) \
|
try { \
|
||||||
} while( Catch::isTrue( false ) )
|
if( __catchResult.allowThrows() ) \
|
||||||
|
expr; \
|
||||||
|
__catchResult.captureResult( Catch::ResultWas::DidntThrowException ); \
|
||||||
|
} \
|
||||||
|
catch( ... ) { \
|
||||||
|
__catchResult.captureResult( Catch::ResultWas::Ok ); \
|
||||||
|
} \
|
||||||
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_THROWS_AS( expr, exceptionType, resultDisposition, macroName ) \
|
#define INTERNAL_CATCH_THROWS_AS( expr, exceptionType, resultDisposition, macroName ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
|
||||||
INTERNAL_CATCH_THROWS_IMPL( expr, exceptionType, resultDisposition ) \
|
try { \
|
||||||
catch( ... ) { \
|
if( __catchResult.allowThrows() ) \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( ( Catch::ExpressionResultBuilder( Catch::ResultWas::ThrewException ) << Catch::translateActiveException() ), \
|
expr; \
|
||||||
resultDisposition | Catch::ResultDisposition::ContinueOnFailure, false ); \
|
__catchResult.captureResult( Catch::ResultWas::DidntThrowException ); \
|
||||||
} \
|
} \
|
||||||
} while( Catch::isTrue( false ) )
|
catch( exceptionType ) { \
|
||||||
|
__catchResult.captureResult( Catch::ResultWas::Ok ); \
|
||||||
|
} \
|
||||||
|
catch( ... ) { \
|
||||||
|
__catchResult.useActiveException( resultDisposition ); \
|
||||||
|
} \
|
||||||
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#ifdef CATCH_CONFIG_VARIADIC_MACROS
|
#ifdef CATCH_CONFIG_VARIADIC_MACROS
|
||||||
#define INTERNAL_CATCH_MSG( messageType, resultDisposition, macroName, ... ) \
|
#define INTERNAL_CATCH_MSG( messageType, resultDisposition, macroName, ... ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, "", resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, "", resultDisposition ); \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( messageType ) << __VA_ARGS__ +::Catch::StreamEndStop(), resultDisposition, true ) \
|
__catchResult.m_resultBuilder << __VA_ARGS__ + ::Catch::StreamEndStop(); \
|
||||||
} while( Catch::isTrue( false ) )
|
__catchResult.captureResult( messageType ); \
|
||||||
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
#else
|
#else
|
||||||
#define INTERNAL_CATCH_MSG( messageType, resultDisposition, macroName, log ) \
|
#define INTERNAL_CATCH_MSG( messageType, resultDisposition, macroName, log ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, "", resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, "", resultDisposition ); \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( Catch::ExpressionResultBuilder( messageType ) << log, resultDisposition, true ) \
|
__catchResult.m_resultBuilder << log + ::Catch::StreamEndStop(); \
|
||||||
} while( Catch::isTrue( false ) )
|
__catchResult.captureResult( messageType ); \
|
||||||
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CATCH_INFO( log, macroName ) \
|
#define INTERNAL_CATCH_INFO( log, macroName ) \
|
||||||
Catch::ScopedMessage INTERNAL_CATCH_UNIQUE_NAME( scopedMessage ) = Catch::MessageBuilder( macroName, CATCH_INTERNAL_LINEINFO, Catch::ResultWas::Info ) << log;
|
Catch::ScopedMessage INTERNAL_CATCH_UNIQUE_NAME( scopedMessage ) = Catch::MessageBuilder( macroName, CATCH_INTERNAL_LINEINFO, Catch::ResultWas::Info ) << log;
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
#define INTERNAL_CHECK_THAT( arg, matcher, resultDisposition, macroName ) \
|
#define INTERNAL_CHECK_THAT( arg, matcher, resultDisposition, macroName ) \
|
||||||
do { \
|
do { \
|
||||||
Catch::AssertionInfo __assertionInfo( macroName, CATCH_INTERNAL_LINEINFO, #arg " " #matcher, resultDisposition ); \
|
Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #arg " " #matcher, resultDisposition ); \
|
||||||
try { \
|
try { \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( ( Catch::expressionResultBuilderFromMatcher( ::Catch::Matchers::matcher, arg, #matcher ) ), resultDisposition, false ); \
|
std::string matcherAsString = ::Catch::Matchers::matcher.toString(); \
|
||||||
} catch( Catch::TestFailureException& ) { \
|
__catchResult.m_resultBuilder \
|
||||||
throw; \
|
.setLhs( Catch::toString( arg ) ) \
|
||||||
|
.setRhs( matcherAsString == "{?}" ? #matcher : matcherAsString ) \
|
||||||
|
.setOp( "matches" ) \
|
||||||
|
.setResultType( ::Catch::Matchers::matcher.match( arg ) ); \
|
||||||
|
__catchResult.captureExpression(); \
|
||||||
} catch( ... ) { \
|
} catch( ... ) { \
|
||||||
INTERNAL_CATCH_ACCEPT_EXPR( ( Catch::ExpressionResultBuilder( Catch::ResultWas::ThrewException ) << Catch::translateActiveException() ), \
|
__catchResult.useActiveException( resultDisposition | Catch::ResultDisposition::ContinueOnFailure ); \
|
||||||
resultDisposition | Catch::ResultDisposition::ContinueOnFailure, false ); \
|
|
||||||
} \
|
} \
|
||||||
} while( Catch::isTrue( false ) )
|
INTERNAL_CATCH_REACT( __catchResult ) \
|
||||||
|
} while( Catch::alwaysFalse() )
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_CAPTURE_HPP_INCLUDED
|
||||||
|
@ -94,6 +94,8 @@ namespace Catch {
|
|||||||
|
|
||||||
// This is just here to avoid compiler warnings with macro constants and boolean literals
|
// This is just here to avoid compiler warnings with macro constants and boolean literals
|
||||||
inline bool isTrue( bool value ){ return value; }
|
inline bool isTrue( bool value ){ return value; }
|
||||||
|
inline bool alwaysTrue() { return true; }
|
||||||
|
inline bool alwaysFalse() { return false; }
|
||||||
|
|
||||||
void throwLogicError( std::string const& message, SourceLineInfo const& locationInfo );
|
void throwLogicError( std::string const& message, SourceLineInfo const& locationInfo );
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ namespace Catch {
|
|||||||
void throwLogicError( std::string const& message, SourceLineInfo const& locationInfo ) {
|
void throwLogicError( std::string const& message, SourceLineInfo const& locationInfo ) {
|
||||||
std::ostringstream oss;
|
std::ostringstream oss;
|
||||||
oss << locationInfo << ": Internal Catch error: '" << message << "'";
|
oss << locationInfo << ": Internal Catch error: '" << message << "'";
|
||||||
if( isTrue( true ))
|
if( alwaysTrue() )
|
||||||
throw std::logic_error( oss.str() );
|
throw std::logic_error( oss.str() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ namespace Catch{
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef CATCH_BREAK_INTO_DEBUGGER
|
#ifndef CATCH_BREAK_INTO_DEBUGGER
|
||||||
#define CATCH_BREAK_INTO_DEBUGGER() Catch::isTrue( true );
|
#define CATCH_BREAK_INTO_DEBUGGER() Catch::alwaysTrue();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_DEBUGGER_H_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_DEBUGGER_H_INCLUDED
|
||||||
|
@ -41,6 +41,9 @@ namespace Catch {
|
|||||||
throw;
|
throw;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
catch( TestFailureException& ) {
|
||||||
|
throw;
|
||||||
|
}
|
||||||
catch( std::exception& ex ) {
|
catch( std::exception& ex ) {
|
||||||
return ex.what();
|
return ex.what();
|
||||||
}
|
}
|
||||||
|
@ -1,31 +0,0 @@
|
|||||||
/*
|
|
||||||
* Created by Phil on 11/5/2012.
|
|
||||||
* Copyright 2012 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)
|
|
||||||
*/
|
|
||||||
#ifndef TWOBLUECUBES_CATCH_EXPRESSION_DECOMPOSER_HPP_INCLUDED
|
|
||||||
#define TWOBLUECUBES_CATCH_EXPRESSION_DECOMPOSER_HPP_INCLUDED
|
|
||||||
|
|
||||||
#include "catch_expression_lhs.hpp"
|
|
||||||
|
|
||||||
namespace Catch {
|
|
||||||
|
|
||||||
// Captures the LHS of the expression and wraps it in an Expression Lhs object
|
|
||||||
class ExpressionDecomposer {
|
|
||||||
public:
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
ExpressionLhs<T const&> operator->* ( T const& operand ) {
|
|
||||||
return ExpressionLhs<T const&>( operand );
|
|
||||||
}
|
|
||||||
|
|
||||||
ExpressionLhs<bool> operator->* ( bool value ) {
|
|
||||||
return ExpressionLhs<bool>( value );
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // end namespace Catch
|
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_EXPRESSION_DECOMPOSER_HPP_INCLUDED
|
|
@ -8,12 +8,19 @@
|
|||||||
#ifndef TWOBLUECUBES_CATCH_EXPRESSION_LHS_HPP_INCLUDED
|
#ifndef TWOBLUECUBES_CATCH_EXPRESSION_LHS_HPP_INCLUDED
|
||||||
#define TWOBLUECUBES_CATCH_EXPRESSION_LHS_HPP_INCLUDED
|
#define TWOBLUECUBES_CATCH_EXPRESSION_LHS_HPP_INCLUDED
|
||||||
|
|
||||||
|
#include "catch_result_builder.h"
|
||||||
#include "catch_expressionresult_builder.h"
|
#include "catch_expressionresult_builder.h"
|
||||||
#include "catch_evaluate.hpp"
|
#include "catch_evaluate.hpp"
|
||||||
#include "catch_tostring.h"
|
#include "catch_tostring.h"
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
|
struct ResultBuilder;
|
||||||
|
|
||||||
|
ExpressionResultBuilder& getResultBuilder( ResultBuilder* rb );
|
||||||
|
|
||||||
// Wraps the LHS of an expression and captures the operator and RHS (if any) -
|
// Wraps the LHS of an expression and captures the operator and RHS (if any) -
|
||||||
// wrapping them all in an ExpressionResultBuilder object
|
// wrapping them all in an ExpressionResultBuilder object
|
||||||
template<typename T>
|
template<typename T>
|
||||||
@ -24,7 +31,7 @@ class ExpressionLhs {
|
|||||||
# endif
|
# endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ExpressionLhs( T lhs ) : m_lhs( lhs ) {}
|
ExpressionLhs( ResultBuilder& rb, T lhs ) : m_rb( &rb ), m_lhs( lhs ) {}
|
||||||
# ifdef CATCH_CPP11_OR_GREATER
|
# ifdef CATCH_CPP11_OR_GREATER
|
||||||
ExpressionLhs( ExpressionLhs const& ) = default;
|
ExpressionLhs( ExpressionLhs const& ) = default;
|
||||||
ExpressionLhs( ExpressionLhs && ) = default;
|
ExpressionLhs( ExpressionLhs && ) = default;
|
||||||
@ -68,12 +75,13 @@ public:
|
|||||||
return captureExpression<Internal::IsNotEqualTo>( rhs );
|
return captureExpression<Internal::IsNotEqualTo>( rhs );
|
||||||
}
|
}
|
||||||
|
|
||||||
ExpressionResultBuilder& endExpression( ResultDisposition::Flags resultDisposition ) {
|
void endExpression() {
|
||||||
|
assert( m_rb );
|
||||||
bool value = m_lhs ? true : false;
|
bool value = m_lhs ? true : false;
|
||||||
return m_result
|
getResultBuilder( m_rb )
|
||||||
.setLhs( Catch::toString( value ) )
|
.setLhs( Catch::toString( value ) )
|
||||||
.setResultType( value )
|
.setResultType( value )
|
||||||
.endExpression( resultDisposition );
|
.endExpression();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only simple binary expressions are allowed on the LHS.
|
// Only simple binary expressions are allowed on the LHS.
|
||||||
@ -88,7 +96,8 @@ public:
|
|||||||
private:
|
private:
|
||||||
template<Internal::Operator Op, typename RhsT>
|
template<Internal::Operator Op, typename RhsT>
|
||||||
ExpressionResultBuilder& captureExpression( RhsT const& rhs ) {
|
ExpressionResultBuilder& captureExpression( RhsT const& rhs ) {
|
||||||
return m_result
|
assert( m_rb );
|
||||||
|
return getResultBuilder( m_rb )
|
||||||
.setResultType( Internal::compare<Op>( m_lhs, rhs ) )
|
.setResultType( Internal::compare<Op>( m_lhs, rhs ) )
|
||||||
.setLhs( Catch::toString( m_lhs ) )
|
.setLhs( Catch::toString( m_lhs ) )
|
||||||
.setRhs( Catch::toString( rhs ) )
|
.setRhs( Catch::toString( rhs ) )
|
||||||
@ -96,7 +105,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ExpressionResultBuilder m_result;
|
ResultBuilder* m_rb;
|
||||||
T m_lhs;
|
T m_lhs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -17,15 +17,16 @@
|
|||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
struct STATIC_ASSERT_Expression_Too_Complex_Please_Rewrite_As_Binary_Comparison;
|
struct STATIC_ASSERT_Expression_Too_Complex_Please_Rewrite_As_Binary_Comparison;
|
||||||
|
struct ResultBuilder;
|
||||||
|
|
||||||
// Wraps the (stringised versions of) the lhs, operator and rhs of an expression - as well as
|
// Wraps the (stringised versions of) the lhs, operator and rhs of an expression - as well as
|
||||||
// the result of evaluating it. This is used to build an AssertionResult object
|
// the result of evaluating it. This is used to build an AssertionResult object
|
||||||
class ExpressionResultBuilder {
|
class ExpressionResultBuilder {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
ExpressionResultBuilder( ResultWas::OfType resultType = ResultWas::Unknown );
|
ExpressionResultBuilder( ResultBuilder* rb, ResultWas::OfType resultType = ResultWas::Unknown );
|
||||||
ExpressionResultBuilder( ExpressionResultBuilder const& other );
|
ExpressionResultBuilder( ExpressionResultBuilder const& other );
|
||||||
ExpressionResultBuilder& operator=(ExpressionResultBuilder const& other );
|
ExpressionResultBuilder& operator=( ExpressionResultBuilder const& other );
|
||||||
|
|
||||||
ExpressionResultBuilder& setResultType( ResultWas::OfType result );
|
ExpressionResultBuilder& setResultType( ResultWas::OfType result );
|
||||||
ExpressionResultBuilder& setResultType( bool result );
|
ExpressionResultBuilder& setResultType( bool result );
|
||||||
@ -33,7 +34,7 @@ public:
|
|||||||
ExpressionResultBuilder& setRhs( std::string const& rhs );
|
ExpressionResultBuilder& setRhs( std::string const& rhs );
|
||||||
ExpressionResultBuilder& setOp( std::string const& op );
|
ExpressionResultBuilder& setOp( std::string const& op );
|
||||||
|
|
||||||
ExpressionResultBuilder& endExpression( ResultDisposition::Flags resultDisposition );
|
void endExpression();
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
ExpressionResultBuilder& operator << ( T const& value ) {
|
ExpressionResultBuilder& operator << ( T const& value ) {
|
||||||
@ -49,6 +50,7 @@ public:
|
|||||||
template<typename RhsT> STATIC_ASSERT_Expression_Too_Complex_Please_Rewrite_As_Binary_Comparison& operator || ( RhsT const& );
|
template<typename RhsT> STATIC_ASSERT_Expression_Too_Complex_Please_Rewrite_As_Binary_Comparison& operator || ( RhsT const& );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
ResultBuilder* m_rb;
|
||||||
AssertionResultData m_data;
|
AssertionResultData m_data;
|
||||||
struct ExprComponents {
|
struct ExprComponents {
|
||||||
ExprComponents() : shouldNegate( false ) {}
|
ExprComponents() : shouldNegate( false ) {}
|
||||||
|
@ -9,21 +9,25 @@
|
|||||||
#define TWOBLUECUBES_CATCH_EXPRESSIONRESULT_BUILDER_HPP_INCLUDED
|
#define TWOBLUECUBES_CATCH_EXPRESSIONRESULT_BUILDER_HPP_INCLUDED
|
||||||
|
|
||||||
#include "catch_expressionresult_builder.h"
|
#include "catch_expressionresult_builder.h"
|
||||||
|
#include "catch_result_builder.h"
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
ExpressionResultBuilder::ExpressionResultBuilder( ResultWas::OfType resultType ) {
|
ExpressionResultBuilder::ExpressionResultBuilder( ResultBuilder* rb, ResultWas::OfType resultType )
|
||||||
|
: m_rb( rb ) {
|
||||||
m_data.resultType = resultType;
|
m_data.resultType = resultType;
|
||||||
}
|
}
|
||||||
ExpressionResultBuilder::ExpressionResultBuilder( ExpressionResultBuilder const& other )
|
ExpressionResultBuilder::ExpressionResultBuilder( ExpressionResultBuilder const& other )
|
||||||
: m_data( other.m_data ),
|
: m_rb( other.m_rb ),
|
||||||
|
m_data( other.m_data ),
|
||||||
m_exprComponents( other.m_exprComponents )
|
m_exprComponents( other.m_exprComponents )
|
||||||
{
|
{
|
||||||
m_stream << other.m_stream.str();
|
m_stream << other.m_stream.str();
|
||||||
}
|
}
|
||||||
ExpressionResultBuilder& ExpressionResultBuilder::operator=(ExpressionResultBuilder const& other ) {
|
ExpressionResultBuilder& ExpressionResultBuilder::operator=(ExpressionResultBuilder const& other ) {
|
||||||
|
m_rb = other.m_rb;
|
||||||
m_data = other.m_data;
|
m_data = other.m_data;
|
||||||
m_exprComponents = other.m_exprComponents;
|
m_exprComponents = other.m_exprComponents;
|
||||||
m_stream.str("");
|
m_stream.str("");
|
||||||
@ -38,9 +42,9 @@ namespace Catch {
|
|||||||
m_data.resultType = result ? ResultWas::Ok : ResultWas::ExpressionFailed;
|
m_data.resultType = result ? ResultWas::Ok : ResultWas::ExpressionFailed;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
ExpressionResultBuilder& ExpressionResultBuilder::endExpression( ResultDisposition::Flags resultDisposition ) {
|
void ExpressionResultBuilder::endExpression() {
|
||||||
m_exprComponents.shouldNegate = shouldNegate( resultDisposition );
|
m_exprComponents.shouldNegate = shouldNegate( m_rb->m_assertionInfo.resultDisposition );
|
||||||
return *this;
|
m_rb->captureExpression();
|
||||||
}
|
}
|
||||||
ExpressionResultBuilder& ExpressionResultBuilder::setLhs( std::string const& lhs ) {
|
ExpressionResultBuilder& ExpressionResultBuilder::setLhs( std::string const& lhs ) {
|
||||||
m_exprComponents.lhs = lhs;
|
m_exprComponents.lhs = lhs;
|
||||||
@ -54,6 +58,7 @@ namespace Catch {
|
|||||||
m_exprComponents.op = op;
|
m_exprComponents.op = op;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
AssertionResult ExpressionResultBuilder::buildResult( AssertionInfo const& info ) const
|
AssertionResult ExpressionResultBuilder::buildResult( AssertionInfo const& info ) const
|
||||||
{
|
{
|
||||||
assert( m_data.resultType != ResultWas::Unknown );
|
assert( m_data.resultType != ResultWas::Unknown );
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include "catch_section.hpp"
|
#include "catch_section.hpp"
|
||||||
#include "catch_debugger.hpp"
|
#include "catch_debugger.hpp"
|
||||||
#include "catch_tostring.hpp"
|
#include "catch_tostring.hpp"
|
||||||
|
#include "catch_result_builder.hpp"
|
||||||
|
|
||||||
#include "../reporters/catch_reporter_xml.hpp"
|
#include "../reporters/catch_reporter_xml.hpp"
|
||||||
#include "../reporters/catch_reporter_junit.hpp"
|
#include "../reporters/catch_reporter_junit.hpp"
|
||||||
|
@ -34,13 +34,11 @@ namespace Catch {
|
|||||||
virtual void pushScopedMessage( MessageInfo const& message ) = 0;
|
virtual void pushScopedMessage( MessageInfo const& message ) = 0;
|
||||||
virtual void popScopedMessage( MessageInfo const& message ) = 0;
|
virtual void popScopedMessage( MessageInfo const& message ) = 0;
|
||||||
|
|
||||||
virtual bool shouldDebugBreak() const = 0;
|
|
||||||
|
|
||||||
virtual ResultAction::Value acceptExpression( ExpressionResultBuilder const& assertionResult, AssertionInfo const& assertionInfo ) = 0;
|
|
||||||
|
|
||||||
virtual std::string getCurrentTestName() const = 0;
|
virtual std::string getCurrentTestName() const = 0;
|
||||||
virtual const AssertionResult* getLastResult() const = 0;
|
virtual const AssertionResult* getLastResult() const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
IResultCapture& getResultCapture();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_INTERFACES_CAPTURE_H_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_INTERFACES_CAPTURE_H_INCLUDED
|
||||||
|
@ -13,6 +13,7 @@ namespace Catch {
|
|||||||
|
|
||||||
struct IRunner {
|
struct IRunner {
|
||||||
virtual ~IRunner();
|
virtual ~IRunner();
|
||||||
|
virtual bool aborting() const = 0;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ namespace Catch
|
|||||||
it != itEnd;
|
it != itEnd;
|
||||||
++it ) {
|
++it ) {
|
||||||
if( it->type == ResultWas::Info ) {
|
if( it->type == ResultWas::Info ) {
|
||||||
ExpressionResultBuilder expressionBuilder( it->type );
|
ExpressionResultBuilder expressionBuilder( NULL, it->type );
|
||||||
expressionBuilder << it->message;
|
expressionBuilder << it->message;
|
||||||
AssertionInfo info( it->macroName, it->lineInfo, "", ResultDisposition::Normal );
|
AssertionInfo info( it->macroName, it->lineInfo, "", ResultDisposition::Normal );
|
||||||
AssertionResult result = expressionBuilder.buildResult( info );
|
AssertionResult result = expressionBuilder.buildResult( info );
|
||||||
|
49
include/internal/catch_result_builder.h
Normal file
49
include/internal/catch_result_builder.h
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Created by Phil on 28/5/2014.
|
||||||
|
* Copyright 2014 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)
|
||||||
|
*/
|
||||||
|
#ifndef TWOBLUECUBES_CATCH_RESULT_BUILDER_H_INCLUDED
|
||||||
|
#define TWOBLUECUBES_CATCH_RESULT_BUILDER_H_INCLUDED
|
||||||
|
|
||||||
|
#include "catch_expression_lhs.hpp"
|
||||||
|
#include "catch_expressionresult_builder.h"
|
||||||
|
#include "catch_common.h"
|
||||||
|
|
||||||
|
namespace Catch {
|
||||||
|
|
||||||
|
struct TestFailureException{};
|
||||||
|
|
||||||
|
struct ResultBuilder {
|
||||||
|
ResultBuilder( char const* macroName,
|
||||||
|
SourceLineInfo const& lineInfo,
|
||||||
|
char const* capturedExpression,
|
||||||
|
ResultDisposition::Flags resultDisposition );
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
ExpressionLhs<T const&> operator->* ( T const& operand ) {
|
||||||
|
return ExpressionLhs<T const&>( *this, operand );
|
||||||
|
}
|
||||||
|
|
||||||
|
ExpressionLhs<bool> operator->* ( bool value ) {
|
||||||
|
return ExpressionLhs<bool>( *this, value );
|
||||||
|
}
|
||||||
|
|
||||||
|
void useActiveException( ResultDisposition::Flags resultDisposition = ResultDisposition::Normal );
|
||||||
|
void captureResult( ResultWas::OfType resultType );
|
||||||
|
void captureExpression();
|
||||||
|
void react();
|
||||||
|
bool shouldDebugBreak() const;
|
||||||
|
bool allowThrows() const;
|
||||||
|
|
||||||
|
AssertionInfo m_assertionInfo;
|
||||||
|
ExpressionResultBuilder m_resultBuilder;
|
||||||
|
bool m_shouldDebugBreak;
|
||||||
|
bool m_shouldThrow;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // end namespace Catch
|
||||||
|
|
||||||
|
#endif // TWOBLUECUBES_CATCH_RESULT_BUILDER_H_INCLUDED
|
69
include/internal/catch_result_builder.hpp
Normal file
69
include/internal/catch_result_builder.hpp
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/*
|
||||||
|
* Created by Phil on 28/5/2014.
|
||||||
|
* Copyright 2014 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)
|
||||||
|
*/
|
||||||
|
#ifndef TWOBLUECUBES_CATCH_RESULT_BUILDER_HPP_INCLUDED
|
||||||
|
#define TWOBLUECUBES_CATCH_RESULT_BUILDER_HPP_INCLUDED
|
||||||
|
|
||||||
|
#include "catch_result_builder.h"
|
||||||
|
#include "catch_expressionresult_builder.h"
|
||||||
|
#include "catch_context.h"
|
||||||
|
#include "catch_common.h"
|
||||||
|
#include "catch_interfaces_config.h"
|
||||||
|
#include "catch_interfaces_runner.h"
|
||||||
|
#include "catch_interfaces_capture.h"
|
||||||
|
#include "catch_interfaces_registry_hub.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace Catch {
|
||||||
|
|
||||||
|
ExpressionResultBuilder& getResultBuilder( ResultBuilder* rb ) {
|
||||||
|
return rb->m_resultBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
ResultBuilder::ResultBuilder( char const* macroName,
|
||||||
|
SourceLineInfo const& lineInfo,
|
||||||
|
char const* capturedExpression,
|
||||||
|
ResultDisposition::Flags resultDisposition )
|
||||||
|
: m_assertionInfo( macroName, lineInfo, capturedExpression, resultDisposition ),
|
||||||
|
m_resultBuilder( this ),
|
||||||
|
m_shouldDebugBreak( false ),
|
||||||
|
m_shouldThrow( false )
|
||||||
|
{}
|
||||||
|
|
||||||
|
void ResultBuilder::useActiveException( ResultDisposition::Flags resultDisposition ) {
|
||||||
|
m_assertionInfo.resultDisposition = resultDisposition;
|
||||||
|
m_resultBuilder << Catch::translateActiveException();
|
||||||
|
captureResult( ResultWas::ThrewException );
|
||||||
|
}
|
||||||
|
|
||||||
|
void ResultBuilder::captureResult( ResultWas::OfType resultType ) {
|
||||||
|
m_resultBuilder.setResultType( resultType );
|
||||||
|
captureExpression();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ResultBuilder::captureExpression() {
|
||||||
|
AssertionResult result = m_resultBuilder.buildResult( m_assertionInfo );
|
||||||
|
getResultCapture().assertionEnded( result );
|
||||||
|
|
||||||
|
if( !result.isOk() ) {
|
||||||
|
if( getCurrentContext().getConfig()->shouldDebugBreak() )
|
||||||
|
m_shouldDebugBreak = true;
|
||||||
|
if( getCurrentContext().getRunner()->aborting() || m_assertionInfo.resultDisposition == ResultDisposition::Normal )
|
||||||
|
m_shouldThrow = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void ResultBuilder::react() {
|
||||||
|
if( m_shouldThrow )
|
||||||
|
throw Catch::TestFailureException();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ResultBuilder::shouldDebugBreak() const { return m_shouldDebugBreak; }
|
||||||
|
bool ResultBuilder::allowThrows() const { return getCurrentContext().getConfig()->allowThrows(); }
|
||||||
|
|
||||||
|
} // end namespace Catch
|
||||||
|
|
||||||
|
#endif // TWOBLUECUBES_CATCH_RESULT_BUILDER_HPP_INCLUDED
|
@ -36,13 +36,6 @@ namespace Catch {
|
|||||||
return flags == ResultWas::Info;
|
return flags == ResultWas::Info;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ResultAction::Value enum
|
|
||||||
struct ResultAction { enum Value {
|
|
||||||
None,
|
|
||||||
Failed = 1, // Failure - but no debug break if Debug bit not set
|
|
||||||
Debug = 2, // If this bit is set, invoke the debugger
|
|
||||||
Abort = 4 // Test run should abort
|
|
||||||
}; };
|
|
||||||
|
|
||||||
// ResultDisposition::Flags enum
|
// ResultDisposition::Flags enum
|
||||||
struct ResultDisposition { enum Flags {
|
struct ResultDisposition { enum Flags {
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "catch_test_spec.hpp"
|
#include "catch_test_spec.hpp"
|
||||||
#include "catch_test_case_tracker.hpp"
|
#include "catch_test_case_tracker.hpp"
|
||||||
#include "catch_timer.h"
|
#include "catch_timer.h"
|
||||||
|
#include "catch_result_builder.h"
|
||||||
|
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string>
|
#include <string>
|
||||||
@ -129,10 +130,6 @@ namespace Catch {
|
|||||||
|
|
||||||
private: // IResultCapture
|
private: // IResultCapture
|
||||||
|
|
||||||
virtual ResultAction::Value acceptExpression( ExpressionResultBuilder const& assertionResult, AssertionInfo const& assertionInfo ) {
|
|
||||||
m_lastAssertionInfo = assertionInfo;
|
|
||||||
return actOnCurrentResult( assertionResult.buildResult( assertionInfo ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void assertionEnded( AssertionResult const& result ) {
|
virtual void assertionEnded( AssertionResult const& result ) {
|
||||||
if( result.getResultType() == ResultWas::Ok ) {
|
if( result.getResultType() == ResultWas::Ok ) {
|
||||||
@ -147,6 +144,7 @@ namespace Catch {
|
|||||||
|
|
||||||
// Reset working state
|
// Reset working state
|
||||||
m_lastAssertionInfo = AssertionInfo( "", m_lastAssertionInfo.lineInfo, "{Unknown expression after the reported line}" , m_lastAssertionInfo.resultDisposition );
|
m_lastAssertionInfo = AssertionInfo( "", m_lastAssertionInfo.lineInfo, "{Unknown expression after the reported line}" , m_lastAssertionInfo.resultDisposition );
|
||||||
|
m_lastResult = result;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool sectionStarted (
|
virtual bool sectionStarted (
|
||||||
@ -201,10 +199,6 @@ namespace Catch {
|
|||||||
m_messages.erase( std::remove( m_messages.begin(), m_messages.end(), message ), m_messages.end() );
|
m_messages.erase( std::remove( m_messages.begin(), m_messages.end(), message ), m_messages.end() );
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool shouldDebugBreak() const {
|
|
||||||
return m_config->shouldDebugBreak();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual std::string getCurrentTestName() const {
|
virtual std::string getCurrentTestName() const {
|
||||||
return m_activeTestCase
|
return m_activeTestCase
|
||||||
? m_activeTestCase->getTestCaseInfo().name
|
? m_activeTestCase->getTestCaseInfo().name
|
||||||
@ -223,22 +217,6 @@ namespace Catch {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
ResultAction::Value actOnCurrentResult( AssertionResult const& result ) {
|
|
||||||
m_lastResult = result;
|
|
||||||
assertionEnded( m_lastResult );
|
|
||||||
|
|
||||||
ResultAction::Value action = ResultAction::None;
|
|
||||||
|
|
||||||
if( !m_lastResult.isOk() ) {
|
|
||||||
action = ResultAction::Failed;
|
|
||||||
if( shouldDebugBreak() )
|
|
||||||
action = (ResultAction::Value)( action | ResultAction::Debug );
|
|
||||||
if( aborting() )
|
|
||||||
action = (ResultAction::Value)( action | ResultAction::Abort );
|
|
||||||
}
|
|
||||||
return action;
|
|
||||||
}
|
|
||||||
|
|
||||||
void runCurrentTest( std::string& redirectedCout, std::string& redirectedCerr ) {
|
void runCurrentTest( std::string& redirectedCout, std::string& redirectedCerr ) {
|
||||||
TestCaseInfo const& testCaseInfo = m_activeTestCase->getTestCaseInfo();
|
TestCaseInfo const& testCaseInfo = m_activeTestCase->getTestCaseInfo();
|
||||||
SectionInfo testCaseSection( testCaseInfo.name, testCaseInfo.description, testCaseInfo.lineInfo );
|
SectionInfo testCaseSection( testCaseInfo.name, testCaseInfo.description, testCaseInfo.lineInfo );
|
||||||
@ -265,9 +243,11 @@ namespace Catch {
|
|||||||
// This just means the test was aborted due to failure
|
// This just means the test was aborted due to failure
|
||||||
}
|
}
|
||||||
catch(...) {
|
catch(...) {
|
||||||
ExpressionResultBuilder exResult( ResultWas::ThrewException );
|
ResultBuilder exResult( m_lastAssertionInfo.macroName.c_str(),
|
||||||
exResult << translateActiveException();
|
m_lastAssertionInfo.lineInfo,
|
||||||
actOnCurrentResult( exResult.buildResult( m_lastAssertionInfo ) );
|
m_lastAssertionInfo.capturedExpression.c_str(),
|
||||||
|
m_lastAssertionInfo.resultDisposition );
|
||||||
|
exResult.useActiveException();
|
||||||
}
|
}
|
||||||
// If sections ended prematurely due to an exception we stored their
|
// If sections ended prematurely due to an exception we stored their
|
||||||
// infos here so we can tear them down outside the unwind process.
|
// infos here so we can tear them down outside the unwind process.
|
||||||
@ -314,6 +294,13 @@ namespace Catch {
|
|||||||
std::vector<UnfinishedSections> m_unfinishedSections;
|
std::vector<UnfinishedSections> m_unfinishedSections;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
IResultCapture& getResultCapture() {
|
||||||
|
if( IResultCapture* capture = getCurrentContext().getResultCapture() )
|
||||||
|
return *capture;
|
||||||
|
else
|
||||||
|
throw std::logic_error( "No result capture instance" );
|
||||||
|
}
|
||||||
|
|
||||||
} // end namespace Catch
|
} // end namespace Catch
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_RUNNER_IMPL_HPP_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_RUNNER_IMPL_HPP_INCLUDED
|
||||||
|
@ -5683,7 +5683,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
@ -5696,7 +5696,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
@ -5710,7 +5710,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
@ -5722,7 +5722,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
@ -5735,7 +5735,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
@ -5749,7 +5749,7 @@ TrickyTests.cpp:<line number>
|
|||||||
|
|
||||||
TrickyTests.cpp:<line number>:
|
TrickyTests.cpp:<line number>:
|
||||||
PASSED:
|
PASSED:
|
||||||
REQUIRE( Catch::isTrue( true ) )
|
REQUIRE( Catch::alwaysTrue() )
|
||||||
with expansion:
|
with expansion:
|
||||||
true
|
true
|
||||||
|
|
||||||
|
@ -5849,7 +5849,7 @@ there"
|
|||||||
<TestCase name="Assertions then sections">
|
<TestCase name="Assertions then sections">
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
@ -5858,7 +5858,7 @@ there"
|
|||||||
<Section name="A section">
|
<Section name="A section">
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
@ -5867,7 +5867,7 @@ there"
|
|||||||
<Section name="Another section">
|
<Section name="Another section">
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
@ -5879,7 +5879,7 @@ there"
|
|||||||
</Section>
|
</Section>
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
@ -5888,7 +5888,7 @@ there"
|
|||||||
<Section name="A section">
|
<Section name="A section">
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
@ -5897,7 +5897,7 @@ there"
|
|||||||
<Section name="Another other section">
|
<Section name="Another other section">
|
||||||
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
<Expression success="true" filename="/Users/philnash/Dev/OSS/Catch/projects/SelfTest/TrickyTests.cpp" >
|
||||||
<Original>
|
<Original>
|
||||||
Catch::isTrue( true )
|
Catch::alwaysTrue()
|
||||||
</Original>
|
</Original>
|
||||||
<Expanded>
|
<Expanded>
|
||||||
true
|
true
|
||||||
|
@ -22,42 +22,42 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
Catch::TestCase tcC = fakeTestCase( "longer name with spaces", "[two][three][.][x]" );
|
Catch::TestCase tcC = fakeTestCase( "longer name with spaces", "[two][three][.][x]" );
|
||||||
Catch::TestCase tcD = fakeTestCase( "zlonger name with spacesz", "" );
|
Catch::TestCase tcD = fakeTestCase( "zlonger name with spacesz", "" );
|
||||||
|
|
||||||
SECTION( "Empty test spec should have no filters" ) {
|
SECTION( "Empty test spec should have no filters", "" ) {
|
||||||
TestSpec spec;
|
TestSpec spec;
|
||||||
CHECK( spec.hasFilters() == false );
|
CHECK( spec.hasFilters() == false );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Test spec from empty string should have no filters" ) {
|
SECTION( "Test spec from empty string should have no filters", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "" );
|
TestSpec spec = parseTestSpec( "" );
|
||||||
CHECK( spec.hasFilters() == false );
|
CHECK( spec.hasFilters() == false );
|
||||||
CHECK( spec.matches(tcA ) == false );
|
CHECK( spec.matches(tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Test spec from just a comma should have no filters" ) {
|
SECTION( "Test spec from just a comma should have no filters", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "," );
|
TestSpec spec = parseTestSpec( "," );
|
||||||
CHECK( spec.hasFilters() == false );
|
CHECK( spec.hasFilters() == false );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Test spec from name should have one filter" ) {
|
SECTION( "Test spec from name should have one filter", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "b" );
|
TestSpec spec = parseTestSpec( "b" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == true );
|
CHECK( spec.matches( tcB ) == true );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Test spec from quoted name should have one filter" ) {
|
SECTION( "Test spec from quoted name should have one filter", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "\"b\"" );
|
TestSpec spec = parseTestSpec( "\"b\"" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == true );
|
CHECK( spec.matches( tcB ) == true );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Test spec from name should have one filter" ) {
|
SECTION( "Test spec from name should have one filter", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "b" );
|
TestSpec spec = parseTestSpec( "b" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -65,7 +65,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Wildcard at the start" ) {
|
SECTION( "Wildcard at the start", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*spaces" );
|
TestSpec spec = parseTestSpec( "*spaces" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -74,7 +74,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
CHECK( parseTestSpec( "*a" ).matches( tcA ) == true );
|
CHECK( parseTestSpec( "*a" ).matches( tcA ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Wildcard at the end" ) {
|
SECTION( "Wildcard at the end", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "long*" );
|
TestSpec spec = parseTestSpec( "long*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -83,7 +83,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
CHECK( parseTestSpec( "a*" ).matches( tcA ) == true );
|
CHECK( parseTestSpec( "a*" ).matches( tcA ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Wildcard at both ends" ) {
|
SECTION( "Wildcard at both ends", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*name*" );
|
TestSpec spec = parseTestSpec( "*name*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -92,25 +92,25 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
CHECK( parseTestSpec( "*a*" ).matches( tcA ) == true );
|
CHECK( parseTestSpec( "*a*" ).matches( tcA ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Redundant wildcard at the start" ) {
|
SECTION( "Redundant wildcard at the start", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*a" );
|
TestSpec spec = parseTestSpec( "*a" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "Redundant wildcard at the end" ) {
|
SECTION( "Redundant wildcard at the end", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "a*" );
|
TestSpec spec = parseTestSpec( "a*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "Redundant wildcard at both ends" ) {
|
SECTION( "Redundant wildcard at both ends", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*a*" );
|
TestSpec spec = parseTestSpec( "*a*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "Wildcard at both ends, redundant at start" ) {
|
SECTION( "Wildcard at both ends, redundant at start", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*longer*" );
|
TestSpec spec = parseTestSpec( "*longer*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -118,7 +118,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Just wildcard" ) {
|
SECTION( "Just wildcard", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*" );
|
TestSpec spec = parseTestSpec( "*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
@ -127,35 +127,35 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "Single tag" ) {
|
SECTION( "Single tag", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "[one]" );
|
TestSpec spec = parseTestSpec( "[one]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == true );
|
CHECK( spec.matches( tcB ) == true );
|
||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "Single tag, two matches" ) {
|
SECTION( "Single tag, two matches", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "[x]" );
|
TestSpec spec = parseTestSpec( "[x]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == true );
|
CHECK( spec.matches( tcB ) == true );
|
||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Two tags" ) {
|
SECTION( "Two tags", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "[two][x]" );
|
TestSpec spec = parseTestSpec( "[two][x]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Two tags, spare separated" ) {
|
SECTION( "Two tags, spare separated", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "[two] [x]" );
|
TestSpec spec = parseTestSpec( "[two] [x]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "Wildcarded name and tag" ) {
|
SECTION( "Wildcarded name and tag", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "*name*[x]" );
|
TestSpec spec = parseTestSpec( "*name*[x]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -163,21 +163,21 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "Single tag exclusion" ) {
|
SECTION( "Single tag exclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~[one]" );
|
TestSpec spec = parseTestSpec( "~[one]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
CHECK( spec.matches( tcB ) == false );
|
CHECK( spec.matches( tcB ) == false );
|
||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "One tag exclusion and one tag inclusion" ) {
|
SECTION( "One tag exclusion and one tag inclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~[two][x]" );
|
TestSpec spec = parseTestSpec( "~[two][x]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
CHECK( spec.matches( tcB ) == true );
|
CHECK( spec.matches( tcB ) == true );
|
||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "One tag exclusion and one wldcarded name inclusion" ) {
|
SECTION( "One tag exclusion and one wldcarded name inclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~[two]*name*" );
|
TestSpec spec = parseTestSpec( "~[two]*name*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -185,7 +185,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "One tag exclusion, using exclude:, and one wldcarded name inclusion" ) {
|
SECTION( "One tag exclusion, using exclude:, and one wldcarded name inclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "exclude:[two]*name*" );
|
TestSpec spec = parseTestSpec( "exclude:[two]*name*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -193,7 +193,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "name exclusion" ) {
|
SECTION( "name exclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~b" );
|
TestSpec spec = parseTestSpec( "~b" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
@ -201,7 +201,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == true );
|
CHECK( spec.matches( tcD ) == true );
|
||||||
}
|
}
|
||||||
SECTION( "wildcarded name exclusion" ) {
|
SECTION( "wildcarded name exclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~*name*" );
|
TestSpec spec = parseTestSpec( "~*name*" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
@ -209,7 +209,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "wildcarded name exclusion with tag inclusion" ) {
|
SECTION( "wildcarded name exclusion with tag inclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "~*name*,[three]" );
|
TestSpec spec = parseTestSpec( "~*name*,[three]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
@ -217,7 +217,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "wildcarded name exclusion, using exclude:, with tag inclusion" ) {
|
SECTION( "wildcarded name exclusion, using exclude:, with tag inclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "exclude:*name*,[three]" );
|
TestSpec spec = parseTestSpec( "exclude:*name*,[three]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == true );
|
CHECK( spec.matches( tcA ) == true );
|
||||||
@ -225,7 +225,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "two wildcarded names" ) {
|
SECTION( "two wildcarded names", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "\"longer*\"\"*spaces\"" );
|
TestSpec spec = parseTestSpec( "\"longer*\"\"*spaces\"" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -233,7 +233,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == true );
|
CHECK( spec.matches( tcC ) == true );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "empty tag" ) {
|
SECTION( "empty tag", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "[]" );
|
TestSpec spec = parseTestSpec( "[]" );
|
||||||
CHECK( spec.hasFilters() == false );
|
CHECK( spec.hasFilters() == false );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -241,7 +241,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "empty quoted name" ) {
|
SECTION( "empty quoted name", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "\"\"" );
|
TestSpec spec = parseTestSpec( "\"\"" );
|
||||||
CHECK( spec.hasFilters() == false );
|
CHECK( spec.hasFilters() == false );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
@ -249,7 +249,7 @@ TEST_CASE( "Parse test names and tags", "" ) {
|
|||||||
CHECK( spec.matches( tcC ) == false );
|
CHECK( spec.matches( tcC ) == false );
|
||||||
CHECK( spec.matches( tcD ) == false );
|
CHECK( spec.matches( tcD ) == false );
|
||||||
}
|
}
|
||||||
SECTION( "quoted string followed by tag exclusion" ) {
|
SECTION( "quoted string followed by tag exclusion", "" ) {
|
||||||
TestSpec spec = parseTestSpec( "\"*name*\"~[.]" );
|
TestSpec spec = parseTestSpec( "\"*name*\"~[.]" );
|
||||||
CHECK( spec.hasFilters() == true );
|
CHECK( spec.hasFilters() == true );
|
||||||
CHECK( spec.matches( tcA ) == false );
|
CHECK( spec.matches( tcA ) == false );
|
||||||
|
@ -15,7 +15,7 @@ namespace
|
|||||||
{
|
{
|
||||||
inline int thisThrows()
|
inline int thisThrows()
|
||||||
{
|
{
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw std::domain_error( "expected exception" );
|
throw std::domain_error( "expected exception" );
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -42,14 +42,14 @@ TEST_CASE( "Expected exceptions that don't throw or unexpected exceptions fail t
|
|||||||
|
|
||||||
TEST_CASE( "When unchecked exceptions are thrown directly they are always failures", "[.][failing]" )
|
TEST_CASE( "When unchecked exceptions are thrown directly they are always failures", "[.][failing]" )
|
||||||
{
|
{
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw std::domain_error( "unexpected exception" );
|
throw std::domain_error( "unexpected exception" );
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE( "An unchecked exception reports the line of the last assertion", "[.][failing]" )
|
TEST_CASE( "An unchecked exception reports the line of the last assertion", "[.][failing]" )
|
||||||
{
|
{
|
||||||
CHECK( 1 == 1 );
|
CHECK( 1 == 1 );
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw std::domain_error( "unexpected exception" );
|
throw std::domain_error( "unexpected exception" );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ TEST_CASE( "When unchecked exceptions are thrown from sections they are always f
|
|||||||
{
|
{
|
||||||
SECTION( "section name", "" )
|
SECTION( "section name", "" )
|
||||||
{
|
{
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw std::domain_error( "unexpected exception" );
|
throw std::domain_error( "unexpected exception" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -118,12 +118,12 @@ CATCH_TRANSLATE_EXCEPTION( double& ex )
|
|||||||
|
|
||||||
TEST_CASE("Unexpected custom exceptions can be translated", "[.][failing]" )
|
TEST_CASE("Unexpected custom exceptions can be translated", "[.][failing]" )
|
||||||
{
|
{
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw CustomException( "custom exception" );
|
throw CustomException( "custom exception" );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void throwCustom() {
|
inline void throwCustom() {
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw CustomException( "custom exception - not std" );
|
throw CustomException( "custom exception - not std" );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ TEST_CASE( "Custom exceptions can be translated when testing for throwing as som
|
|||||||
|
|
||||||
TEST_CASE( "Unexpected exceptions can be translated", "[.][failing]" )
|
TEST_CASE( "Unexpected exceptions can be translated", "[.][failing]" )
|
||||||
{
|
{
|
||||||
if( Catch::isTrue( true ) )
|
if( Catch::alwaysTrue() )
|
||||||
throw double( 3.14 );
|
throw double( 3.14 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "catch.hpp"
|
#include "catch.hpp"
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
#ifdef __clang__
|
#ifdef __clang__
|
||||||
#pragma clang diagnostic ignored "-Wc++98-compat-pedantic"
|
#pragma clang diagnostic ignored "-Wc++98-compat-pedantic"
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
#include "catch.hpp"
|
#include "catch.hpp"
|
||||||
|
|
||||||
TEST_CASE( "section tracking" ) {
|
TEST_CASE( "section tracking", "" ) {
|
||||||
|
|
||||||
using namespace Catch;
|
using namespace Catch;
|
||||||
TestCaseTracker testCaseTracker( "test case" );
|
TestCaseTracker testCaseTracker( "test case" );
|
||||||
@ -24,7 +24,7 @@ TEST_CASE( "section tracking" ) {
|
|||||||
|
|
||||||
CHECK_FALSE( testCaseTracker.isCompleted() );
|
CHECK_FALSE( testCaseTracker.isCompleted() );
|
||||||
|
|
||||||
SECTION( "test case with no sections" ) {
|
SECTION( "test case with no sections", "" ) {
|
||||||
|
|
||||||
{
|
{
|
||||||
TestCaseTracker::Guard guard( testCaseTracker );
|
TestCaseTracker::Guard guard( testCaseTracker );
|
||||||
@ -33,7 +33,7 @@ TEST_CASE( "section tracking" ) {
|
|||||||
CHECK( testCaseTracker.isCompleted() );
|
CHECK( testCaseTracker.isCompleted() );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "test case with one section" ) {
|
SECTION( "test case with one section", "" ) {
|
||||||
|
|
||||||
{
|
{
|
||||||
TestCaseTracker::Guard guard( testCaseTracker );
|
TestCaseTracker::Guard guard( testCaseTracker );
|
||||||
@ -58,7 +58,7 @@ TEST_CASE( "section tracking" ) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "test case with two consecutive sections" ) {
|
SECTION( "test case with two consecutive sections", "" ) {
|
||||||
|
|
||||||
// Enter test case
|
// Enter test case
|
||||||
{
|
{
|
||||||
@ -93,7 +93,7 @@ TEST_CASE( "section tracking" ) {
|
|||||||
CHECK( testCaseTracker.isCompleted() );
|
CHECK( testCaseTracker.isCompleted() );
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION( "test case with one section within another" ) {
|
SECTION( "test case with one section within another", "" ) {
|
||||||
|
|
||||||
// Enter test case again
|
// Enter test case again
|
||||||
{
|
{
|
||||||
|
@ -318,19 +318,19 @@ TEST_CASE( "Assertions then sections", "[Tricky]" )
|
|||||||
// This was causing a failure due to the way the console reporter was handling
|
// This was causing a failure due to the way the console reporter was handling
|
||||||
// the current section
|
// the current section
|
||||||
|
|
||||||
REQUIRE( Catch::isTrue( true ) );
|
REQUIRE( Catch::alwaysTrue() );
|
||||||
|
|
||||||
SECTION( "A section", "" )
|
SECTION( "A section", "" )
|
||||||
{
|
{
|
||||||
REQUIRE( Catch::isTrue( true ) );
|
REQUIRE( Catch::alwaysTrue() );
|
||||||
|
|
||||||
SECTION( "Another section", "" )
|
SECTION( "Another section", "" )
|
||||||
{
|
{
|
||||||
REQUIRE( Catch::isTrue( true ) );
|
REQUIRE( Catch::alwaysTrue() );
|
||||||
}
|
}
|
||||||
SECTION( "Another other section", "" )
|
SECTION( "Another other section", "" )
|
||||||
{
|
{
|
||||||
REQUIRE( Catch::isTrue( true ) );
|
REQUIRE( Catch::alwaysTrue() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,8 @@
|
|||||||
261488FD184D21290041FBEB /* catch_section_info.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_section_info.h; sourceTree = "<group>"; };
|
261488FD184D21290041FBEB /* catch_section_info.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_section_info.h; sourceTree = "<group>"; };
|
||||||
261488FE184DC32F0041FBEB /* catch_section.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_section.h; sourceTree = "<group>"; };
|
261488FE184DC32F0041FBEB /* catch_section.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_section.h; sourceTree = "<group>"; };
|
||||||
261488FF184DC4A20041FBEB /* catch_debugger.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_debugger.h; sourceTree = "<group>"; };
|
261488FF184DC4A20041FBEB /* catch_debugger.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_debugger.h; sourceTree = "<group>"; };
|
||||||
|
2627F7051935B16F009BCE2D /* catch_result_builder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = catch_result_builder.h; sourceTree = "<group>"; };
|
||||||
|
2627F7061935B55F009BCE2D /* catch_result_builder.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_result_builder.hpp; sourceTree = "<group>"; };
|
||||||
262E7399184673A800CAC268 /* catch_reporter_bases.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_reporter_bases.hpp; sourceTree = "<group>"; };
|
262E7399184673A800CAC268 /* catch_reporter_bases.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_reporter_bases.hpp; sourceTree = "<group>"; };
|
||||||
262E739A1846759000CAC268 /* catch_common.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_common.hpp; sourceTree = "<group>"; };
|
262E739A1846759000CAC268 /* catch_common.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_common.hpp; sourceTree = "<group>"; };
|
||||||
263FD06017AF8DF200988A20 /* catch_timer.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_timer.hpp; sourceTree = "<group>"; };
|
263FD06017AF8DF200988A20 /* catch_timer.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_timer.hpp; sourceTree = "<group>"; };
|
||||||
@ -104,7 +106,7 @@
|
|||||||
4A4B0F9915CE6EC100AE2392 /* catch_interfaces_registry_hub.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; lineEnding = 0; path = catch_interfaces_registry_hub.h; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.objcpp; };
|
4A4B0F9915CE6EC100AE2392 /* catch_interfaces_registry_hub.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; lineEnding = 0; path = catch_interfaces_registry_hub.h; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.objcpp; };
|
||||||
4A4B0F9A15CEF84800AE2392 /* catch_notimplemented_exception.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_notimplemented_exception.h; sourceTree = "<group>"; };
|
4A4B0F9A15CEF84800AE2392 /* catch_notimplemented_exception.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = catch_notimplemented_exception.h; sourceTree = "<group>"; };
|
||||||
4A4B0F9B15CEF8C400AE2392 /* catch_notimplemented_exception.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_notimplemented_exception.hpp; sourceTree = "<group>"; };
|
4A4B0F9B15CEF8C400AE2392 /* catch_notimplemented_exception.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_notimplemented_exception.hpp; sourceTree = "<group>"; };
|
||||||
4A4B0F9C15CEFA8300AE2392 /* catch_impl.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_impl.hpp; sourceTree = "<group>"; };
|
4A4B0F9C15CEFA8300AE2392 /* catch_impl.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; lineEnding = 0; path = catch_impl.hpp; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.cpp; };
|
||||||
4A6D0C20149B3D3B00DB3EAA /* CatchSelfTest */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = CatchSelfTest; sourceTree = BUILT_PRODUCTS_DIR; };
|
4A6D0C20149B3D3B00DB3EAA /* CatchSelfTest */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = CatchSelfTest; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
4A6D0C26149B3D3B00DB3EAA /* CatchSelfTest.1 */ = {isa = PBXFileReference; lastKnownFileType = text.man; path = CatchSelfTest.1; sourceTree = "<group>"; };
|
4A6D0C26149B3D3B00DB3EAA /* CatchSelfTest.1 */ = {isa = PBXFileReference; lastKnownFileType = text.man; path = CatchSelfTest.1; sourceTree = "<group>"; };
|
||||||
4A6D0C2D149B3D9E00DB3EAA /* ApproxTests.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = ApproxTests.cpp; path = ../../../SelfTest/ApproxTests.cpp; sourceTree = "<group>"; };
|
4A6D0C2D149B3D9E00DB3EAA /* ApproxTests.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = ApproxTests.cpp; path = ../../../SelfTest/ApproxTests.cpp; sourceTree = "<group>"; };
|
||||||
@ -169,7 +171,6 @@
|
|||||||
4AB77CB71553B72B00857BF0 /* catch_section_info.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_section_info.hpp; sourceTree = "<group>"; };
|
4AB77CB71553B72B00857BF0 /* catch_section_info.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_section_info.hpp; sourceTree = "<group>"; };
|
||||||
4ABEA80415C90D2B009F0424 /* catch_objc_arc.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_objc_arc.hpp; sourceTree = "<group>"; };
|
4ABEA80415C90D2B009F0424 /* catch_objc_arc.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_objc_arc.hpp; sourceTree = "<group>"; };
|
||||||
4AC91CCE155CF02800DC5117 /* catch_expression_lhs.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; lineEnding = 0; path = catch_expression_lhs.hpp; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.cpp; };
|
4AC91CCE155CF02800DC5117 /* catch_expression_lhs.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; lineEnding = 0; path = catch_expression_lhs.hpp; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.cpp; };
|
||||||
4AC91CD0155D8DA600DC5117 /* catch_expression_decomposer.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; lineEnding = 0; path = catch_expression_decomposer.hpp; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.cpp; };
|
|
||||||
4ACE21C8166CA19700FB5509 /* catch_option.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_option.hpp; sourceTree = "<group>"; };
|
4ACE21C8166CA19700FB5509 /* catch_option.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_option.hpp; sourceTree = "<group>"; };
|
||||||
4ACE21CA166CA1B300FB5509 /* catch_option.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_option.cpp; path = ../../../SelfTest/SurrogateCpps/catch_option.cpp; sourceTree = "<group>"; };
|
4ACE21CA166CA1B300FB5509 /* catch_option.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_option.cpp; path = ../../../SelfTest/SurrogateCpps/catch_option.cpp; sourceTree = "<group>"; };
|
||||||
4AEE031F16142F910071E950 /* catch_common.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_common.cpp; path = ../../../SelfTest/SurrogateCpps/catch_common.cpp; sourceTree = "<group>"; };
|
4AEE031F16142F910071E950 /* catch_common.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_common.cpp; path = ../../../SelfTest/SurrogateCpps/catch_common.cpp; sourceTree = "<group>"; };
|
||||||
@ -342,6 +343,7 @@
|
|||||||
4A90B59E15D2521E00EF71BC /* catch_expressionresult_builder.hpp */,
|
4A90B59E15D2521E00EF71BC /* catch_expressionresult_builder.hpp */,
|
||||||
4A084F1C15DACEEA0027E631 /* catch_test_case_info.hpp */,
|
4A084F1C15DACEEA0027E631 /* catch_test_case_info.hpp */,
|
||||||
26847E5C16BBACB60043B9C1 /* catch_message.hpp */,
|
26847E5C16BBACB60043B9C1 /* catch_message.hpp */,
|
||||||
|
2627F7061935B55F009BCE2D /* catch_result_builder.hpp */,
|
||||||
);
|
);
|
||||||
name = impl;
|
name = impl;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
@ -361,10 +363,10 @@
|
|||||||
4A6D0C46149B3E3D00DB3EAA /* catch_approx.hpp */,
|
4A6D0C46149B3E3D00DB3EAA /* catch_approx.hpp */,
|
||||||
4A6D0C47149B3E3D00DB3EAA /* catch_capture.hpp */,
|
4A6D0C47149B3E3D00DB3EAA /* catch_capture.hpp */,
|
||||||
4AC91CCE155CF02800DC5117 /* catch_expression_lhs.hpp */,
|
4AC91CCE155CF02800DC5117 /* catch_expression_lhs.hpp */,
|
||||||
4AC91CD0155D8DA600DC5117 /* catch_expression_decomposer.hpp */,
|
|
||||||
4A4B0F9A15CEF84800AE2392 /* catch_notimplemented_exception.h */,
|
4A4B0F9A15CEF84800AE2392 /* catch_notimplemented_exception.h */,
|
||||||
26847E5B16BBAB790043B9C1 /* catch_message.h */,
|
26847E5B16BBAB790043B9C1 /* catch_message.h */,
|
||||||
261488FD184D21290041FBEB /* catch_section_info.h */,
|
261488FD184D21290041FBEB /* catch_section_info.h */,
|
||||||
|
2627F7051935B16F009BCE2D /* catch_result_builder.h */,
|
||||||
);
|
);
|
||||||
name = Assertions;
|
name = Assertions;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
|
Loading…
Reference in New Issue
Block a user