130 lines
3.7 KiB
C++
130 lines
3.7 KiB
C++
/*
|
|
* catch_self_test.cpp
|
|
* Catch
|
|
*
|
|
* Created by Phil on 14/02/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)
|
|
*
|
|
*/
|
|
|
|
#define CATCH_CONFIG_MAIN
|
|
#include "catch_self_test.hpp"
|
|
|
|
namespace Catch{
|
|
|
|
std::size_t EmbeddedRunner::runMatching(
|
|
const std::string& rawTestSpec,
|
|
const std::string& reporter )
|
|
{
|
|
std::ostringstream oss;
|
|
Config config;
|
|
config.setStreamBuf( oss.rdbuf() );
|
|
|
|
//if( reporter == "mock" ) // !TBD
|
|
config.setReporter( m_reporter.get() );
|
|
|
|
std::size_t result;
|
|
|
|
// Scoped because Runner doesn't report EndTesting until its destructor
|
|
{
|
|
Runner runner( config );
|
|
result = runner.runMatching( rawTestSpec );
|
|
m_totals = runner.getTotals();
|
|
}
|
|
m_output = oss.str();
|
|
return result;
|
|
}
|
|
|
|
void MockReporter::Result
|
|
(
|
|
const ResultInfo& resultInfo
|
|
)
|
|
{
|
|
if( resultInfo.getResultType() == ResultWas::Ok )
|
|
return;
|
|
|
|
|
|
switch( resultInfo.getResultType() )
|
|
{
|
|
case ResultWas::Info:
|
|
m_log << "Info";
|
|
break;
|
|
case ResultWas::Warning:
|
|
m_log << "Warning";
|
|
break;
|
|
case ResultWas::ExplicitFailure:
|
|
m_log << "ExplicitFailure";
|
|
break;
|
|
case ResultWas::ExpressionFailed:
|
|
m_log << "ExpressionFailed";
|
|
break;
|
|
case ResultWas::Unknown:
|
|
m_log << "Unknown";
|
|
break;
|
|
case ResultWas::ThrewException:
|
|
m_log << "ThrewException";
|
|
break;
|
|
case ResultWas::DidntThrowException:
|
|
m_log << "DidntThrowException";
|
|
break;
|
|
|
|
// We shouldn't ever see these
|
|
case ResultWas::Ok:
|
|
m_log << "Ok";
|
|
break;
|
|
case ResultWas::FailureBit:
|
|
m_log << "FailureBit";
|
|
break;
|
|
case ResultWas::Exception:
|
|
m_log << "Exception";
|
|
break;
|
|
default:
|
|
m_log << "{unrecognised ResultType enum value}";
|
|
break;
|
|
}
|
|
|
|
if( resultInfo.hasExpression() )
|
|
m_log << resultInfo.getExpression();
|
|
|
|
if( resultInfo.hasMessage() )
|
|
m_log << "'" << resultInfo.getMessage() << "'";
|
|
|
|
if( resultInfo.hasExpandedExpression() )
|
|
m_log << resultInfo.getExpandedExpression();
|
|
}
|
|
|
|
void MockReporter::openLabel( const std::string& label, const std::string& arg )
|
|
{
|
|
if( shouldRecord( label ) )
|
|
{
|
|
m_log << m_indent << "\\" << label;
|
|
if( !arg.empty() )
|
|
m_log << " " << arg;
|
|
m_log << "\n";
|
|
m_indent += " ";
|
|
}
|
|
}
|
|
|
|
void MockReporter::closeLabel( const std::string& label, const std::string& arg )
|
|
{
|
|
if( shouldRecord( label ) )
|
|
{
|
|
m_indent = m_indent.substr( 0, m_indent.size()-1 );
|
|
m_log << m_indent << "/" << label;
|
|
if( !arg.empty() )
|
|
m_log << " " << arg;
|
|
m_log << "\n";
|
|
}
|
|
}
|
|
|
|
const std::string MockReporter::recordGroups = "[g]";
|
|
const std::string MockReporter::recordTestCases = "[tc]";
|
|
const std::string MockReporter::recordSections =" [s]";
|
|
|
|
INTERNAL_CATCH_REGISTER_REPORTER( "mock", MockReporter )
|
|
|
|
}
|