Do not copy around TestCaseInfo

Now a `TEST_CASE` macro should create a single TestCaseInfo and then
it should never be copied around. This, together with latter changes,
should significantly decrease the number of allocations made before
`main` is even entered.
This commit is contained in:
Martin Hořeňovský 2019-11-04 21:35:57 +01:00
parent 019b0a0fe0
commit 302e2c0b06
No known key found for this signature in database
GPG Key ID: DE48307B8B0D381A
33 changed files with 631 additions and 626 deletions

View File

@ -170,7 +170,7 @@ void print( std::ostream& os, int const level, std::string const& title, Catch::
void print( std::ostream& os, int const level, std::string const& title, Catch::TestCaseStats const& info ) { void print( std::ostream& os, int const level, std::string const& title, Catch::TestCaseStats const& info ) {
os << ws(level ) << title << ":\n"; os << ws(level ) << title << ":\n";
print( os, level+1 , "- testInfo", info.testInfo ); print( os, level+1 , "- testInfo", *info.testInfo );
print( os, level+1 , "- totals" , info.totals ); print( os, level+1 , "- totals" , info.totals );
os << ws(level+1) << "- stdOut: " << info.stdOut << "\n" os << ws(level+1) << "- stdOut: " << info.stdOut << "\n"
<< ws(level+1) << "- stdErr: " << info.stdErr << "\n" << ws(level+1) << "- stdErr: " << info.stdErr << "\n"

View File

@ -15,13 +15,15 @@
namespace Catch { namespace Catch {
class TestCase; class TestCaseHandle;
struct TestCaseInfo;
struct ITestCaseRegistry; struct ITestCaseRegistry;
struct IExceptionTranslatorRegistry; struct IExceptionTranslatorRegistry;
struct IExceptionTranslator; struct IExceptionTranslator;
struct IReporterRegistry; struct IReporterRegistry;
struct IReporterFactory; struct IReporterFactory;
struct ITagAliasRegistry; struct ITagAliasRegistry;
struct ITestInvoker;
struct IMutableEnumValuesRegistry; struct IMutableEnumValuesRegistry;
class StartupExceptionRegistry; class StartupExceptionRegistry;
@ -44,7 +46,7 @@ namespace Catch {
virtual ~IMutableRegistryHub(); virtual ~IMutableRegistryHub();
virtual void registerReporter( std::string const& name, IReporterFactoryPtr const& factory ) = 0; virtual void registerReporter( std::string const& name, IReporterFactoryPtr const& factory ) = 0;
virtual void registerListener( IReporterFactoryPtr const& factory ) = 0; virtual void registerListener( IReporterFactoryPtr const& factory ) = 0;
virtual void registerTest( TestCase const& testInfo ) = 0; virtual void registerTest(std::unique_ptr<TestCaseInfo>&& testInfo, std::unique_ptr<ITestInvoker>&& invoker) = 0;
virtual void registerTranslator( const IExceptionTranslator* translator ) = 0; virtual void registerTranslator( const IExceptionTranslator* translator ) = 0;
virtual void registerTagAlias( std::string const& alias, std::string const& tag, SourceLineInfo const& lineInfo ) = 0; virtual void registerTagAlias( std::string const& alias, std::string const& tag, SourceLineInfo const& lineInfo ) = 0;
virtual void registerStartupException() noexcept = 0; virtual void registerStartupException() noexcept = 0;

View File

@ -76,7 +76,7 @@ namespace Catch {
std::string const& _stdOut, std::string const& _stdOut,
std::string const& _stdErr, std::string const& _stdErr,
bool _aborting ) bool _aborting )
: testInfo( _testInfo ), : testInfo( &_testInfo ),
totals( _totals ), totals( _totals ),
stdOut( _stdOut ), stdOut( _stdOut ),
stdErr( _stdErr ), stdErr( _stdErr ),
@ -141,14 +141,15 @@ namespace Catch {
Catch::cout() << std::endl; Catch::cout() << std::endl;
} }
void IStreamingReporter::listTests(std::vector<TestCase> const& tests, Config const& config) { void IStreamingReporter::listTests(std::vector<TestCaseHandle> const& tests, Config const& config) {
if (config.hasTestFilters()) if (config.hasTestFilters())
Catch::cout() << "Matching test cases:\n"; Catch::cout() << "Matching test cases:\n";
else { else {
Catch::cout() << "All available test cases:\n"; Catch::cout() << "All available test cases:\n";
} }
for (auto const& testCaseInfo : tests) { for (auto const& test : tests) {
auto const& testCaseInfo = test.getTestCaseInfo();
Colour::Code colour = testCaseInfo.isHidden() Colour::Code colour = testCaseInfo.isHidden()
? Colour::SecondaryText ? Colour::SecondaryText
: Colour::None; : Colour::None;

View File

@ -128,7 +128,7 @@ namespace Catch {
TestCaseStats& operator = ( TestCaseStats && ) = default; TestCaseStats& operator = ( TestCaseStats && ) = default;
virtual ~TestCaseStats(); virtual ~TestCaseStats();
TestCaseInfo testInfo; TestCaseInfo const * testInfo;
Totals totals; Totals totals;
std::string stdOut; std::string stdOut;
std::string stdErr; std::string stdErr;
@ -250,7 +250,7 @@ namespace Catch {
// Listing support // Listing support
virtual void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config); virtual void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config);
virtual void listTests(std::vector<TestCase> const& tests, Config const& config); virtual void listTests(std::vector<TestCaseHandle> const& tests, Config const& config);
virtual void listTags(std::vector<TagInfo> const& tags, Config const& config); virtual void listTags(std::vector<TagInfo> const& tags, Config const& config);
}; };

View File

@ -19,19 +19,19 @@ namespace Catch {
virtual ~ITestInvoker(); virtual ~ITestInvoker();
}; };
class TestCase; class TestCaseHandle;
struct IConfig; struct IConfig;
struct ITestCaseRegistry { struct ITestCaseRegistry {
virtual ~ITestCaseRegistry(); virtual ~ITestCaseRegistry();
virtual std::vector<TestCase> const& getAllTests() const = 0; virtual std::vector<TestCaseHandle> const& getAllTests() const = 0;
virtual std::vector<TestCase> const& getAllTestsSorted( IConfig const& config ) const = 0; virtual std::vector<TestCaseHandle> const& getAllTestsSorted( IConfig const& config ) const = 0;
}; };
bool isThrowSafe( TestCase const& testCase, IConfig const& config ); bool isThrowSafe( TestCaseHandle const& testCase, IConfig const& config );
bool matchTest( TestCase const& testCase, TestSpec const& testSpec, IConfig const& config ); bool matchTest( TestCaseHandle const& testCase, TestSpec const& testSpec, IConfig const& config );
std::vector<TestCase> filterTests( std::vector<TestCase> const& testCases, TestSpec const& testSpec, IConfig const& config ); std::vector<TestCaseHandle> filterTests( std::vector<TestCaseHandle> const& testCases, TestSpec const& testSpec, IConfig const& config );
std::vector<TestCase> const& getAllTestCasesSorted( IConfig const& config ); std::vector<TestCaseHandle> const& getAllTestCasesSorted( IConfig const& config );
} }

View File

@ -36,7 +36,7 @@ namespace Catch {
void listTags(IStreamingReporter& reporter, Config const& config) { void listTags(IStreamingReporter& reporter, Config const& config) {
TestSpec testSpec = config.testSpec(); TestSpec testSpec = config.testSpec();
std::vector<TestCase> matchedTestCases = filterTests(getAllTestCasesSorted(config), testSpec, config); std::vector<TestCaseHandle> matchedTestCases = filterTests(getAllTestCasesSorted(config), testSpec, config);
std::map<std::string, TagInfo> tagCounts; std::map<std::string, TagInfo> tagCounts;
for (auto const& testCase : matchedTestCases) { for (auto const& testCase : matchedTestCases) {

View File

@ -93,7 +93,7 @@ namespace Catch {
std::string desc = Detail::getAnnotation( cls, "Description", testCaseName ); std::string desc = Detail::getAnnotation( cls, "Description", testCaseName );
const char* className = class_getName( cls ); const char* className = class_getName( cls );
getMutableRegistryHub().registerTest( makeTestCase( new OcMethod( cls, selector ), className, NameAndTags( name.c_str(), desc.c_str() ), SourceLineInfo("",0) ) ); getMutableRegistryHub().registerTest( makeTestCaseInfo( new OcMethod( cls, selector ), className, NameAndTags( name.c_str(), desc.c_str() ), SourceLineInfo("",0) ) );
noTestMethods++; noTestMethods++;
} }
} }

View File

@ -49,8 +49,8 @@ namespace Catch {
void registerListener( IReporterFactoryPtr const& factory ) override { void registerListener( IReporterFactoryPtr const& factory ) override {
m_reporterRegistry.registerListener( factory ); m_reporterRegistry.registerListener( factory );
} }
void registerTest( TestCase const& testInfo ) override { void registerTest( std::unique_ptr<TestCaseInfo>&& testInfo, std::unique_ptr<ITestInvoker>&& invoker ) override {
m_testCaseRegistry.registerTest( testInfo ); m_testCaseRegistry.registerTest( std::move(testInfo), std::move(invoker) );
} }
void registerTranslator( const IExceptionTranslator* translator ) override { void registerTranslator( const IExceptionTranslator* translator ) override {
m_exceptionTranslatorRegistry.registerTranslator( translator ); m_exceptionTranslatorRegistry.registerTranslator( translator );

View File

@ -93,7 +93,7 @@ namespace Catch {
m_reporter->testGroupEnded(TestGroupStats(GroupInfo(testSpec, groupIndex, groupsCount), totals, aborting())); m_reporter->testGroupEnded(TestGroupStats(GroupInfo(testSpec, groupIndex, groupsCount), totals, aborting()));
} }
Totals RunContext::runTest(TestCase const& testCase) { Totals RunContext::runTest(TestCaseHandle const& testCase) {
Totals prevTotals = m_totals; Totals prevTotals = m_totals;
std::string redirectedCout; std::string redirectedCout;

View File

@ -44,7 +44,7 @@ namespace Catch {
void testGroupStarting( std::string const& testSpec, std::size_t groupIndex, std::size_t groupsCount ); void testGroupStarting( std::string const& testSpec, std::size_t groupIndex, std::size_t groupsCount );
void testGroupEnded( std::string const& testSpec, Totals const& totals, std::size_t groupIndex, std::size_t groupsCount ); void testGroupEnded( std::string const& testSpec, Totals const& totals, std::size_t groupIndex, std::size_t groupsCount );
Totals runTest(TestCase const& testCase); Totals runTest(TestCaseHandle const& testCase);
IConfigPtr config() const; IConfigPtr config() const;
IStreamingReporter& reporter() const; IStreamingReporter& reporter() const;
@ -133,7 +133,7 @@ namespace Catch {
TestRunInfo m_runInfo; TestRunInfo m_runInfo;
IMutableContext& m_context; IMutableContext& m_context;
TestCase const* m_activeTestCase = nullptr; TestCaseHandle const* m_activeTestCase = nullptr;
ITracker* m_testCaseTracker = nullptr; ITracker* m_testCaseTracker = nullptr;
Option<AssertionResult> m_lastResult; Option<AssertionResult> m_lastResult;

View File

@ -72,7 +72,7 @@ namespace Catch {
if (m_matches.empty() && invalidArgs.empty()) { if (m_matches.empty() && invalidArgs.empty()) {
for (auto const& test : allTestCases) for (auto const& test : allTestCases)
if (!test.isHidden()) if (!test.getTestCaseInfo().isHidden())
m_tests.emplace(&test); m_tests.emplace(&test);
} else { } else {
for (auto const& match : m_matches) for (auto const& match : m_matches)
@ -88,7 +88,7 @@ namespace Catch {
if (!m_context.aborting()) if (!m_context.aborting())
totals += m_context.runTest(*testCase); totals += m_context.runTest(*testCase);
else else
m_context.reporter().skipTest(*testCase); m_context.reporter().skipTest(testCase->getTestCaseInfo());
} }
for (auto const& match : m_matches) { for (auto const& match : m_matches) {
@ -108,7 +108,7 @@ namespace Catch {
} }
private: private:
using Tests = std::set<TestCase const*>; using Tests = std::set<TestCaseHandle const*>;
std::shared_ptr<Config> m_config; std::shared_ptr<Config> m_config;
RunContext m_context; RunContext m_context;
@ -117,11 +117,11 @@ namespace Catch {
}; };
void applyFilenamesAsTags(Catch::IConfig const& config) { void applyFilenamesAsTags(Catch::IConfig const& config) {
auto& tests = const_cast<std::vector<TestCase>&>(getAllTestCasesSorted(config)); for (auto const& testCase : getAllTestCasesSorted(config)) {
for (auto& testCase : tests) { // Yeah, sue me. This will be removed soon.
auto tags = testCase.tags; auto& testInfo = const_cast<TestCaseInfo&>(testCase.getTestCaseInfo());
std::string filename = testCase.lineInfo.file; std::string filename = testInfo.lineInfo.file;
auto lastSlash = filename.find_last_of("\\/"); auto lastSlash = filename.find_last_of("\\/");
if (lastSlash != std::string::npos) { if (lastSlash != std::string::npos) {
filename.erase(0, lastSlash); filename.erase(0, lastSlash);
@ -133,8 +133,9 @@ namespace Catch {
filename.erase(lastDot); filename.erase(lastDot);
} }
auto tags = testInfo.tags;
tags.push_back(std::move(filename)); tags.push_back(std::move(filename));
setTags(testCase, tags); setTags(testInfo, tags);
} }
} }

View File

@ -53,8 +53,8 @@ namespace Catch {
} }
} }
TestCase makeTestCase( ITestInvoker* _testCase, std::unique_ptr<TestCaseInfo>
std::string const& _className, makeTestCaseInfo(std::string const& _className,
NameAndTags const& nameAndTags, NameAndTags const& nameAndTags,
SourceLineInfo const& _lineInfo ) SourceLineInfo const& _lineInfo )
{ {
@ -95,8 +95,8 @@ namespace Catch {
tags.push_back( "." ); tags.push_back( "." );
} }
TestCaseInfo info( static_cast<std::string>(nameAndTags.name), _className, tags, _lineInfo ); return std::make_unique<TestCaseInfo>(static_cast<std::string>(nameAndTags.name),
return TestCase( _testCase, std::move(info) ); _className, tags, _lineInfo);
} }
void setTags( TestCaseInfo& testCaseInfo, std::vector<std::string> tags ) { void setTags( TestCaseInfo& testCaseInfo, std::vector<std::string> tags ) {
@ -155,26 +155,18 @@ namespace Catch {
} }
TestCase::TestCase( ITestInvoker* testCase, TestCaseInfo&& info ) : TestCaseInfo( std::move(info) ), test( testCase ) {} bool TestCaseHandle::operator == ( TestCaseHandle const& rhs ) const {
return m_invoker == rhs.m_invoker
&& m_info->name == rhs.m_info->name
void TestCase::invoke() const { && m_info->className == rhs.m_info->className;
test->invoke();
} }
bool TestCase::operator == ( TestCase const& other ) const { bool TestCaseHandle::operator < ( TestCaseHandle const& rhs ) const {
return test.get() == other.test.get() && return m_info->name < rhs.m_info->name;
name == other.name &&
className == other.className;
} }
bool TestCase::operator < ( TestCase const& other ) const { TestCaseInfo const& TestCaseHandle::getTestCaseInfo() const {
return name < other.name; return *m_info;
}
TestCaseInfo const& TestCase::getTestCaseInfo() const
{
return *this;
} }
} // end namespace Catch } // end namespace Catch

View File

@ -24,7 +24,7 @@ namespace Catch {
struct ITestInvoker; struct ITestInvoker;
struct TestCaseInfo { struct TestCaseInfo : NonCopyable {
enum SpecialProperties{ enum SpecialProperties{
None = 0, None = 0,
IsHidden = 1 << 1, IsHidden = 1 << 1,
@ -57,24 +57,24 @@ namespace Catch {
SpecialProperties properties; SpecialProperties properties;
}; };
class TestCase : public TestCaseInfo { class TestCaseHandle {
TestCaseInfo* m_info;
ITestInvoker* m_invoker;
public: public:
TestCaseHandle(TestCaseInfo* info, ITestInvoker* invoker) :
m_info(info), m_invoker(invoker) {}
TestCase( ITestInvoker* testCase, TestCaseInfo&& info ); void invoke() const {
m_invoker->invoke();
void invoke() const; }
TestCaseInfo const& getTestCaseInfo() const; TestCaseInfo const& getTestCaseInfo() const;
bool operator == ( TestCase const& other ) const; bool operator== ( TestCaseHandle const& rhs ) const;
bool operator < ( TestCase const& other ) const; bool operator < ( TestCaseHandle const& rhs ) const;
private:
std::shared_ptr<ITestInvoker> test;
}; };
TestCase makeTestCase( ITestInvoker* testCase, std::unique_ptr<TestCaseInfo> makeTestCaseInfo( std::string const& className,
std::string const& className,
NameAndTags const& nameAndTags, NameAndTags const& nameAndTags,
SourceLineInfo const& lineInfo ); SourceLineInfo const& lineInfo );
} }

View File

@ -19,9 +19,9 @@
namespace Catch { namespace Catch {
std::vector<TestCase> sortTests( IConfig const& config, std::vector<TestCase> const& unsortedTestCases ) { std::vector<TestCaseHandle> sortTests( IConfig const& config, std::vector<TestCaseHandle> const& unsortedTestCases ) {
std::vector<TestCase> sorted = unsortedTestCases; std::vector<TestCaseHandle> sorted = unsortedTestCases;
switch( config.runOrder() ) { switch( config.runOrder() ) {
case RunTests::InLexicographicalOrder: case RunTests::InLexicographicalOrder:
@ -38,53 +38,55 @@ namespace Catch {
return sorted; return sorted;
} }
bool isThrowSafe( TestCase const& testCase, IConfig const& config ) { bool isThrowSafe( TestCaseHandle const& testCase, IConfig const& config ) {
return !testCase.throws() || config.allowThrows(); return !testCase.getTestCaseInfo().throws() || config.allowThrows();
} }
bool matchTest( TestCase const& testCase, TestSpec const& testSpec, IConfig const& config ) { bool matchTest( TestCaseHandle const& testCase, TestSpec const& testSpec, IConfig const& config ) {
return testSpec.matches( testCase ) && isThrowSafe( testCase, config ); return testSpec.matches( testCase.getTestCaseInfo() ) && isThrowSafe( testCase, config );
} }
void enforceNoDuplicateTestCases( std::vector<TestCase> const& functions ) { void enforceNoDuplicateTestCases( std::vector<TestCaseHandle> const& functions ) {
std::set<TestCase> seenFunctions; std::set<TestCaseHandle> seenFunctions;
for( auto const& function : functions ) { for( auto const& function : functions ) {
auto prev = seenFunctions.insert( function ); auto prev = seenFunctions.insert( function );
CATCH_ENFORCE( prev.second, CATCH_ENFORCE( prev.second,
"error: TEST_CASE( \"" << function.name << "\" ) already defined.\n" "error: TEST_CASE( \"" << function.getTestCaseInfo().name << "\" ) already defined.\n"
<< "\tFirst seen at " << prev.first->getTestCaseInfo().lineInfo << "\n" << "\tFirst seen at " << prev.first->getTestCaseInfo().lineInfo << "\n"
<< "\tRedefined at " << function.getTestCaseInfo().lineInfo ); << "\tRedefined at " << function.getTestCaseInfo().lineInfo );
} }
} }
std::vector<TestCase> filterTests( std::vector<TestCase> const& testCases, TestSpec const& testSpec, IConfig const& config ) { std::vector<TestCaseHandle> filterTests( std::vector<TestCaseHandle> const& testCases, TestSpec const& testSpec, IConfig const& config ) {
std::vector<TestCase> filtered; std::vector<TestCaseHandle> filtered;
filtered.reserve( testCases.size() ); filtered.reserve( testCases.size() );
for (auto const& testCase : testCases) { for (auto const& testCase : testCases) {
if ((!testSpec.hasFilters() && !testCase.isHidden()) || if ((!testSpec.hasFilters() && !testCase.getTestCaseInfo().isHidden()) ||
(testSpec.hasFilters() && matchTest(testCase, testSpec, config))) { (testSpec.hasFilters() && matchTest(testCase, testSpec, config))) {
filtered.push_back(testCase); filtered.push_back(testCase);
} }
} }
return filtered; return filtered;
} }
std::vector<TestCase> const& getAllTestCasesSorted( IConfig const& config ) { std::vector<TestCaseHandle> const& getAllTestCasesSorted( IConfig const& config ) {
return getRegistryHub().getTestCaseRegistry().getAllTestsSorted( config ); return getRegistryHub().getTestCaseRegistry().getAllTestsSorted( config );
} }
void TestRegistry::registerTest( TestCase const& testCase ) { void TestRegistry::registerTest(std::unique_ptr<TestCaseInfo> testInfo, std::unique_ptr<ITestInvoker> testInvoker) {
m_functions.push_back( testCase ); m_handles.emplace_back(testInfo.get(), testInvoker.get());
m_infos.push_back(std::move(testInfo));
m_invokers.push_back(std::move(testInvoker));
} }
std::vector<TestCase> const& TestRegistry::getAllTests() const { std::vector<TestCaseHandle> const& TestRegistry::getAllTests() const {
return m_functions; return m_handles;
} }
std::vector<TestCase> const& TestRegistry::getAllTestsSorted( IConfig const& config ) const { std::vector<TestCaseHandle> const& TestRegistry::getAllTestsSorted( IConfig const& config ) const {
if( m_sortedFunctions.empty() ) if( m_sortedFunctions.empty() )
enforceNoDuplicateTestCases( m_functions ); enforceNoDuplicateTestCases( m_handles );
if( m_currentSortOrder != config.runOrder() || m_sortedFunctions.empty() ) { if( m_currentSortOrder != config.runOrder() || m_sortedFunctions.empty() ) {
m_sortedFunctions = sortTests( config, m_functions ); m_sortedFunctions = sortTests( config, m_handles );
m_currentSortOrder = config.runOrder(); m_currentSortOrder = config.runOrder();
} }
return m_sortedFunctions; return m_sortedFunctions;
@ -93,8 +95,6 @@ namespace Catch {
/////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////
TestInvokerAsFunction::TestInvokerAsFunction( void(*testAsFunction)() ) noexcept : m_testAsFunction( testAsFunction ) {}
void TestInvokerAsFunction::invoke() const { void TestInvokerAsFunction::invoke() const {
m_testAsFunction(); m_testAsFunction();
} }

View File

@ -15,44 +15,47 @@
#include <vector> #include <vector>
#include <set> #include <set>
#include <algorithm> #include <algorithm>
#include <ios>
namespace Catch { namespace Catch {
class TestCase; class TestCaseHandle;
struct IConfig; struct IConfig;
std::vector<TestCase> sortTests( IConfig const& config, std::vector<TestCase> const& unsortedTestCases ); std::vector<TestCaseHandle> sortTests( IConfig const& config, std::vector<TestCaseHandle> const& unsortedTestCases );
bool isThrowSafe( TestCase const& testCase, IConfig const& config ); bool isThrowSafe( TestCaseHandle const& testCase, IConfig const& config );
bool matchTest( TestCase const& testCase, TestSpec const& testSpec, IConfig const& config ); bool matchTest( TestCaseHandle const& testCase, TestSpec const& testSpec, IConfig const& config );
void enforceNoDuplicateTestCases( std::vector<TestCase> const& functions ); void enforceNoDuplicateTestCases( std::vector<TestCaseHandle> const& functions );
std::vector<TestCase> filterTests( std::vector<TestCase> const& testCases, TestSpec const& testSpec, IConfig const& config ); std::vector<TestCaseHandle> filterTests( std::vector<TestCaseHandle> const& testCases, TestSpec const& testSpec, IConfig const& config );
std::vector<TestCase> const& getAllTestCasesSorted( IConfig const& config ); std::vector<TestCaseHandle> const& getAllTestCasesSorted( IConfig const& config );
class TestRegistry : public ITestCaseRegistry { class TestRegistry : public ITestCaseRegistry {
public: public:
virtual ~TestRegistry() = default; virtual ~TestRegistry() = default;
virtual void registerTest( TestCase const& testCase ); virtual void registerTest( std::unique_ptr<TestCaseInfo> testInfo, std::unique_ptr<ITestInvoker> testInvoker );
std::vector<TestCase> const& getAllTests() const override; std::vector<TestCaseHandle> const& getAllTests() const override;
std::vector<TestCase> const& getAllTestsSorted( IConfig const& config ) const override; std::vector<TestCaseHandle> const& getAllTestsSorted( IConfig const& config ) const override;
private: private:
std::vector<TestCase> m_functions; std::vector<std::unique_ptr<TestCaseInfo>> m_infos;
std::vector<std::unique_ptr<ITestInvoker>> m_invokers;
std::vector<TestCaseHandle> m_handles;
mutable RunTests::InWhatOrder m_currentSortOrder = RunTests::InDeclarationOrder; mutable RunTests::InWhatOrder m_currentSortOrder = RunTests::InDeclarationOrder;
mutable std::vector<TestCase> m_sortedFunctions; mutable std::vector<TestCaseHandle> m_sortedFunctions;
}; };
/////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////
class TestInvokerAsFunction : public ITestInvoker { class TestInvokerAsFunction final : public ITestInvoker {
void(*m_testAsFunction)(); using TestType = void(*)();
TestType m_testAsFunction;
public: public:
TestInvokerAsFunction( void(*testAsFunction)() ) noexcept; TestInvokerAsFunction(TestType testAsFunction) noexcept:
m_testAsFunction(testAsFunction) {}
void invoke() const override; void invoke() const override;
}; };

View File

@ -12,19 +12,19 @@
namespace Catch { namespace Catch {
auto makeTestInvoker( void(*testAsFunction)() ) noexcept -> ITestInvoker* { std::unique_ptr<ITestInvoker> makeTestInvoker( void(*testAsFunction)() ) {
return new(std::nothrow) TestInvokerAsFunction( testAsFunction ); return std::make_unique<TestInvokerAsFunction>( testAsFunction );
} }
AutoReg::AutoReg( ITestInvoker* invoker, SourceLineInfo const& lineInfo, StringRef const& classOrMethod, NameAndTags const& nameAndTags ) noexcept { AutoReg::AutoReg( std::unique_ptr<ITestInvoker> invoker, SourceLineInfo const& lineInfo, StringRef const& classOrMethod, NameAndTags const& nameAndTags ) noexcept {
CATCH_TRY { CATCH_TRY {
getMutableRegistryHub() getMutableRegistryHub()
.registerTest( .registerTest(
makeTestCase( makeTestCaseInfo(
invoker,
extractClassName( classOrMethod ), extractClassName( classOrMethod ),
nameAndTags, nameAndTags,
lineInfo)); lineInfo),
std::move(invoker));
} CATCH_CATCH_ALL { } CATCH_CATCH_ALL {
// Do not throw when constructing global objects, instead register the exception to be processed later // Do not throw when constructing global objects, instead register the exception to be processed later
getMutableRegistryHub().registerStartupException(); getMutableRegistryHub().registerStartupException();

View File

@ -15,6 +15,8 @@
#include "catch_preprocessor.hpp" #include "catch_preprocessor.hpp"
#include "catch_meta.hpp" #include "catch_meta.hpp"
#include <memory>
namespace Catch { namespace Catch {
template<typename C> template<typename C>
@ -29,11 +31,11 @@ public:
} }
}; };
auto makeTestInvoker( void(*testAsFunction)() ) noexcept -> ITestInvoker*; std::unique_ptr<ITestInvoker> makeTestInvoker( void(*testAsFunction)() );
template<typename C> template<typename C>
auto makeTestInvoker( void (C::*testAsMethod)() ) noexcept -> ITestInvoker* { std::unique_ptr<ITestInvoker> makeTestInvoker( void (C::*testAsMethod)() ) {
return new(std::nothrow) TestInvokerAsMethod<C>( testAsMethod ); return std::make_unique<TestInvokerAsMethod<C>>( testAsMethod );
} }
struct NameAndTags { struct NameAndTags {
@ -45,7 +47,7 @@ struct NameAndTags {
}; };
struct AutoReg : NonCopyable { struct AutoReg : NonCopyable {
AutoReg( ITestInvoker* invoker, SourceLineInfo const& lineInfo, StringRef const& classOrMethod, NameAndTags const& nameAndTags ) noexcept; AutoReg( std::unique_ptr<ITestInvoker> invoker, SourceLineInfo const& lineInfo, StringRef const& classOrMethod, NameAndTags const& nameAndTags ) noexcept;
}; };
} // end namespace Catch } // end namespace Catch

View File

@ -84,13 +84,13 @@ namespace Catch {
return std::any_of( m_filters.begin(), m_filters.end(), [&]( Filter const& f ){ return f.matches( testCase ); } ); return std::any_of( m_filters.begin(), m_filters.end(), [&]( Filter const& f ){ return f.matches( testCase ); } );
} }
TestSpec::Matches TestSpec::matchesByFilter( std::vector<TestCase> const& testCases, IConfig const& config ) const TestSpec::Matches TestSpec::matchesByFilter( std::vector<TestCaseHandle> const& testCases, IConfig const& config ) const
{ {
Matches matches( m_filters.size() ); Matches matches( m_filters.size() );
std::transform( m_filters.begin(), m_filters.end(), matches.begin(), [&]( Filter const& filter ){ std::transform( m_filters.begin(), m_filters.end(), matches.begin(), [&]( Filter const& filter ){
std::vector<TestCase const*> currentMatches; std::vector<TestCaseHandle const*> currentMatches;
for( auto const& test : testCases ) for( auto const& test : testCases )
if( isThrowSafe( test, config ) && filter.matches( test ) ) if( isThrowSafe( test, config ) && filter.matches( test.getTestCaseInfo() ) )
currentMatches.emplace_back( &test ); currentMatches.emplace_back( &test );
return FilterMatch{ filter.name(), currentMatches }; return FilterMatch{ filter.name(), currentMatches };
} ); } );

View File

@ -63,14 +63,14 @@ namespace Catch {
public: public:
struct FilterMatch { struct FilterMatch {
std::string name; std::string name;
std::vector<TestCase const*> tests; std::vector<TestCaseHandle const*> tests;
}; };
using Matches = std::vector<FilterMatch>; using Matches = std::vector<FilterMatch>;
using vectorStrings = std::vector<std::string>; using vectorStrings = std::vector<std::string>;
bool hasFilters() const; bool hasFilters() const;
bool matches( TestCaseInfo const& testCase ) const; bool matches( TestCaseInfo const& testCase ) const;
Matches matchesByFilter( std::vector<TestCase> const& testCases, IConfig const& config ) const; Matches matchesByFilter( std::vector<TestCaseHandle> const& testCases, IConfig const& config ) const;
const vectorStrings & getInvalidArgs() const; const vectorStrings & getInvalidArgs() const;
private: private:

View File

@ -41,7 +41,7 @@ namespace Catch {
} else { } else {
stream << "FAIL"; stream << "FAIL";
} }
stream << ' ' << _testCaseStats.testInfo.name << '\n'; stream << ' ' << _testCaseStats.testInfo->name << '\n';
StreamingReporterBase::testCaseEnded( _testCaseStats ); StreamingReporterBase::testCaseEnded( _testCaseStats );
} }

View File

@ -55,7 +55,7 @@ namespace Catch {
} }
void testCaseStarting(TestCaseInfo const& _testInfo) override { void testCaseStarting(TestCaseInfo const& _testInfo) override {
currentTestCaseInfo = _testInfo; currentTestCaseInfo = &_testInfo;
} }
void sectionStarting(SectionInfo const& _sectionInfo) override { void sectionStarting(SectionInfo const& _sectionInfo) override {
m_sectionStack.push_back(_sectionInfo); m_sectionStack.push_back(_sectionInfo);
@ -65,13 +65,13 @@ namespace Catch {
m_sectionStack.pop_back(); m_sectionStack.pop_back();
} }
void testCaseEnded(TestCaseStats const& /* _testCaseStats */) override { void testCaseEnded(TestCaseStats const& /* _testCaseStats */) override {
currentTestCaseInfo.reset(); currentTestCaseInfo = nullptr;
} }
void testGroupEnded(TestGroupStats const& /* _testGroupStats */) override { void testGroupEnded(TestGroupStats const& /* _testGroupStats */) override {
currentGroupInfo.reset(); currentGroupInfo.reset();
} }
void testRunEnded(TestRunStats const& /* _testRunStats */) override { void testRunEnded(TestRunStats const& /* _testRunStats */) override {
currentTestCaseInfo.reset(); currentTestCaseInfo = nullptr;
currentGroupInfo.reset(); currentGroupInfo.reset();
currentTestRunInfo.reset(); currentTestRunInfo.reset();
} }
@ -86,7 +86,7 @@ namespace Catch {
LazyStat<TestRunInfo> currentTestRunInfo; LazyStat<TestRunInfo> currentTestRunInfo;
LazyStat<GroupInfo> currentGroupInfo; LazyStat<GroupInfo> currentGroupInfo;
LazyStat<TestCaseInfo> currentTestCaseInfo; TestCaseInfo const* currentTestCaseInfo;
std::vector<SectionInfo> m_sectionStack; std::vector<SectionInfo> m_sectionStack;
ReporterPreferences m_reporterPrefs; ReporterPreferences m_reporterPrefs;
@ -261,7 +261,7 @@ namespace Catch {
// Event listeners should not use the default listing impl // Event listeners should not use the default listing impl
void listReporters(std::vector<ReporterDescription> const&, Config const&) override {} void listReporters(std::vector<ReporterDescription> const&, Config const&) override {}
void listTests(std::vector<TestCase> const&, Config const&) override {} void listTests(std::vector<TestCaseHandle> const&, Config const&) override {}
void listTags(std::vector<TagInfo> const&, Config const&) override {} void listTags(std::vector<TagInfo> const&, Config const&) override {}
}; };

View File

@ -159,10 +159,10 @@ namespace Catch {
assert( testCaseNode.children.size() == 1 ); assert( testCaseNode.children.size() == 1 );
SectionNode const& rootSection = *testCaseNode.children.front(); SectionNode const& rootSection = *testCaseNode.children.front();
std::string className = stats.testInfo.className; std::string className = stats.testInfo->className;
if( className.empty() ) { if( className.empty() ) {
className = fileNameTag(stats.testInfo.tags); className = fileNameTag(stats.testInfo->tags);
if ( className.empty() ) if ( className.empty() )
className = "global"; className = "global";
} }

View File

@ -163,7 +163,7 @@ namespace Catch {
m_reporter->listReporters(descriptions, config); m_reporter->listReporters(descriptions, config);
} }
void ListeningReporter::listTests(std::vector<TestCase> const& tests, Config const& config) { void ListeningReporter::listTests(std::vector<TestCaseHandle> const& tests, Config const& config) {
for (auto const& listener : m_listeners) { for (auto const& listener : m_listeners) {
listener->listTests(tests, config); listener->listTests(tests, config);
} }

View File

@ -55,7 +55,7 @@ namespace Catch {
bool isMulti() const override; bool isMulti() const override;
void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config) override; void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config) override;
void listTests(std::vector<TestCase> const& tests, Config const& config) override; void listTests(std::vector<TestCaseHandle> const& tests, Config const& config) override;
void listTags(std::vector<TagInfo> const& tags, Config const& config) override; void listTags(std::vector<TagInfo> const& tags, Config const& config) override;

View File

@ -58,7 +58,7 @@ namespace Catch {
void writeGroup(TestGroupNode const& groupNode) { void writeGroup(TestGroupNode const& groupNode) {
std::map<std::string, TestGroupNode::ChildNodes> testsPerFile; std::map<std::string, TestGroupNode::ChildNodes> testsPerFile;
for(auto const& child : groupNode.children) for(auto const& child : groupNode.children)
testsPerFile[child->value.testInfo.lineInfo.file].push_back(child); testsPerFile[child->value.testInfo->lineInfo.file].push_back(child);
for(auto const& kv : testsPerFile) for(auto const& kv : testsPerFile)
writeTestFile(kv.first.c_str(), kv.second); writeTestFile(kv.first.c_str(), kv.second);
@ -77,7 +77,7 @@ namespace Catch {
// test case itself. That section may have 0-n nested sections // test case itself. That section may have 0-n nested sections
assert(testCaseNode.children.size() == 1); assert(testCaseNode.children.size() == 1);
SectionNode const& rootSection = *testCaseNode.children.front(); SectionNode const& rootSection = *testCaseNode.children.front();
writeSection("", rootSection, testCaseNode.value.testInfo.okToFail()); writeSection("", rootSection, testCaseNode.value.testInfo->okToFail());
} }
void writeSection(std::string const& rootName, SectionNode const& sectionNode, bool okToFail) { void writeSection(std::string const& rootName, SectionNode const& sectionNode, bool okToFail) {

View File

@ -152,16 +152,17 @@ namespace Catch {
void testCaseEnded( TestCaseStats const& testCaseStats ) override { void testCaseEnded( TestCaseStats const& testCaseStats ) override {
StreamingReporterBase::testCaseEnded( testCaseStats ); StreamingReporterBase::testCaseEnded( testCaseStats );
auto const& testCaseInfo = *testCaseStats.testInfo;
if( !testCaseStats.stdOut.empty() ) if( !testCaseStats.stdOut.empty() )
stream << "##teamcity[testStdOut name='" stream << "##teamcity[testStdOut name='"
<< escape( testCaseStats.testInfo.name ) << escape( testCaseInfo.name )
<< "' out='" << escape( testCaseStats.stdOut ) << "']\n"; << "' out='" << escape( testCaseStats.stdOut ) << "']\n";
if( !testCaseStats.stdErr.empty() ) if( !testCaseStats.stdErr.empty() )
stream << "##teamcity[testStdErr name='" stream << "##teamcity[testStdErr name='"
<< escape( testCaseStats.testInfo.name ) << escape(testCaseInfo.name )
<< "' out='" << escape( testCaseStats.stdErr ) << "']\n"; << "' out='" << escape( testCaseStats.stdErr ) << "']\n";
stream << "##teamcity[testFinished name='" stream << "##teamcity[testFinished name='"
<< escape( testCaseStats.testInfo.name ) << "' duration='" << escape(testCaseInfo.name ) << "' duration='"
<< m_testTimer.getElapsedMilliseconds() << "']\n"; << m_testTimer.getElapsedMilliseconds() << "']\n";
stream.flush(); stream.flush();
} }

View File

@ -277,7 +277,7 @@ namespace Catch {
} }
} }
void XmlReporter::listTests(std::vector<TestCase> const& tests, Config const&) { void XmlReporter::listTests(std::vector<TestCaseHandle> const& tests, Config const&) {
auto outerTag = m_xml.scopedElement("MatchingTests"); auto outerTag = m_xml.scopedElement("MatchingTests");
for (auto const& test : tests) { for (auto const& test : tests) {
auto innerTag = m_xml.scopedElement("TestCase"); auto innerTag = m_xml.scopedElement("TestCase");

View File

@ -58,7 +58,7 @@ namespace Catch {
#endif // CATCH_CONFIG_ENABLE_BENCHMARKING #endif // CATCH_CONFIG_ENABLE_BENCHMARKING
void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config) override; void listReporters(std::vector<ReporterDescription> const& descriptions, Config const& config) override;
void listTests(std::vector<TestCase> const& tests, Config const& config) override; void listTests(std::vector<TestCaseHandle> const& tests, Config const& config) override;
void listTags(std::vector<TagInfo> const& tags, Config const& config) override; void listTags(std::vector<TagInfo> const& tags, Config const& config) override;
private: private:

View File

@ -883,150 +883,150 @@ RandomNumberGeneration.tests.cpp:<line number>: passed: rng() == 0x<hex digits>
Message.tests.cpp:<line number>: failed: explicitly with 1 message: 'Message from section one' Message.tests.cpp:<line number>: failed: explicitly with 1 message: 'Message from section one'
Message.tests.cpp:<line number>: failed: explicitly with 1 message: 'Message from section two' Message.tests.cpp:<line number>: failed: explicitly with 1 message: 'Message from section two'
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches(tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "*a" ).matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "*a" ).matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "a*" ).matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "a*" ).matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "*a*" ).matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: parseTestSpec( "*a*" ).matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.hasFilters() == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcA ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcA ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcB ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcB ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcC ) == false for: false == false CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcC ) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: spec.matches( tcD ) == true for: true == true CmdLine.tests.cpp:<line number>: passed: spec.matches( *tcD ) == true for: true == true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark" ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark" ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( "aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( "aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( "aardvark" ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( "aardvark" ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark" ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark" ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( " aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( " aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( "aardvark " ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( "aardvark " ) ) for: true
CmdLine.tests.cpp:<line number>: passed: spec.matches( fakeTestCase( "aardvark" ) ) for: true CmdLine.tests.cpp:<line number>: passed: spec.matches( *fakeTestCase( "aardvark" ) ) for: true
Condition.tests.cpp:<line number>: passed: p == 0 for: 0 == 0 Condition.tests.cpp:<line number>: passed: p == 0 for: 0 == 0
Condition.tests.cpp:<line number>: passed: p == pNULL for: 0 == 0 Condition.tests.cpp:<line number>: passed: p == pNULL for: 0 == 0
Condition.tests.cpp:<line number>: passed: p != 0 for: 0x<hex digits> != 0 Condition.tests.cpp:<line number>: passed: p != 0 for: 0x<hex digits> != 0
@ -1051,16 +1051,16 @@ CmdLine.tests.cpp:<line number>: passed: config.reporterName == "console" for: "
CmdLine.tests.cpp:<line number>: passed: !(cfg.hasTestFilters()) for: !false CmdLine.tests.cpp:<line number>: passed: !(cfg.hasTestFilters()) for: !false
CmdLine.tests.cpp:<line number>: passed: result for: {?} CmdLine.tests.cpp:<line number>: passed: result for: {?}
CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("notIncluded")) == false for: false == false CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("notIncluded")) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("test1")) for: true CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("test1")) for: true
CmdLine.tests.cpp:<line number>: passed: result for: {?} CmdLine.tests.cpp:<line number>: passed: result for: {?}
CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("test1")) == false for: false == false CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("test1")) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) for: true CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) for: true
CmdLine.tests.cpp:<line number>: passed: result for: {?} CmdLine.tests.cpp:<line number>: passed: result for: {?}
CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true CmdLine.tests.cpp:<line number>: passed: cfg.hasTestFilters() for: true
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("test1")) == false for: false == false CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("test1")) == false for: false == false
CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) for: true CmdLine.tests.cpp:<line number>: passed: cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) for: true
CmdLine.tests.cpp:<line number>: passed: cli.parse({"test", "-r", "console"}) for: {?} CmdLine.tests.cpp:<line number>: passed: cli.parse({"test", "-r", "console"}) for: {?}
CmdLine.tests.cpp:<line number>: passed: config.reporterName == "console" for: "console" == "console" CmdLine.tests.cpp:<line number>: passed: config.reporterName == "console" for: "console" == "console"
CmdLine.tests.cpp:<line number>: passed: cli.parse({"test", "-r", "xml"}) for: {?} CmdLine.tests.cpp:<line number>: passed: cli.parse({"test", "-r", "xml"}) for: {?}
@ -1662,7 +1662,7 @@ StringManip.tests.cpp:<line number>: passed: Catch::replaceInPlace(s, "'", "|'")
StringManip.tests.cpp:<line number>: passed: s == "didn|'t" for: "didn|'t" == "didn|'t" StringManip.tests.cpp:<line number>: passed: s == "didn|'t" for: "didn|'t" == "didn|'t"
Misc.tests.cpp:<line number>: failed: false with 1 message: '3' Misc.tests.cpp:<line number>: failed: false with 1 message: '3'
Message.tests.cpp:<line number>: failed: false with 2 messages: 'hi' and 'i := 7' Message.tests.cpp:<line number>: failed: false with 2 messages: 'hi' and 'i := 7'
Tag.tests.cpp:<line number>: passed: testcase.tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string(".")) for: { ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." ) Tag.tests.cpp:<line number>: passed: testcase->tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string(".")) for: { ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." )
StringManip.tests.cpp:<line number>: passed: splitStringRef("", ','), Equals(std::vector<StringRef>()) for: { } Equals: { } StringManip.tests.cpp:<line number>: passed: splitStringRef("", ','), Equals(std::vector<StringRef>()) for: { } Equals: { }
StringManip.tests.cpp:<line number>: passed: splitStringRef("abc", ','), Equals(std::vector<StringRef>{"abc"}) for: { abc } Equals: { abc } StringManip.tests.cpp:<line number>: passed: splitStringRef("abc", ','), Equals(std::vector<StringRef>{"abc"}) for: { abc } Equals: { abc }
StringManip.tests.cpp:<line number>: passed: splitStringRef("abc,def", ','), Equals(std::vector<StringRef>{"abc", "def"}) for: { abc, def } Equals: { abc, def } StringManip.tests.cpp:<line number>: passed: splitStringRef("abc,def", ','), Equals(std::vector<StringRef>{"abc", "def"}) for: { abc, def } Equals: { abc, def }

View File

@ -6418,12 +6418,12 @@ with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6440,12 +6440,12 @@ with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches(tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6462,12 +6462,12 @@ with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6484,12 +6484,12 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
@ -6506,12 +6506,12 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
@ -6528,17 +6528,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
@ -6555,27 +6555,27 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( parseTestSpec( "*a" ).matches( tcA ) == true ) CHECK( parseTestSpec( "*a" ).matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
@ -6592,27 +6592,27 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( parseTestSpec( "a*" ).matches( tcA ) == true ) CHECK( parseTestSpec( "a*" ).matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
@ -6629,27 +6629,27 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( parseTestSpec( "*a*" ).matches( tcA ) == true ) CHECK( parseTestSpec( "*a*" ).matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
@ -6666,12 +6666,12 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6688,12 +6688,12 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6710,12 +6710,12 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
@ -6732,22 +6732,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -6764,22 +6764,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -6796,17 +6796,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
@ -6823,17 +6823,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
@ -6850,17 +6850,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
@ -6877,17 +6877,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
@ -6904,22 +6904,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -6936,17 +6936,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
@ -6963,17 +6963,17 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
@ -6990,22 +6990,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -7022,22 +7022,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -7054,22 +7054,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -7086,22 +7086,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7118,22 +7118,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7150,22 +7150,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == true ) CHECK( spec.matches( *tcA ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == true ) CHECK( spec.matches( *tcB ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7182,22 +7182,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == true ) CHECK( spec.matches( *tcC ) == true )
with expansion: with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7214,22 +7214,22 @@ with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7246,22 +7246,22 @@ with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == false ) CHECK( spec.matches( *tcD ) == false )
with expansion: with expansion:
false == false false == false
@ -7278,22 +7278,22 @@ with expansion:
true == true true == true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcA ) == false ) CHECK( spec.matches( *tcA ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcB ) == false ) CHECK( spec.matches( *tcB ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcC ) == false ) CHECK( spec.matches( *tcC ) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( tcD ) == true ) CHECK( spec.matches( *tcD ) == true )
with expansion: with expansion:
true == true true == true
@ -7305,27 +7305,27 @@ CmdLine.tests.cpp:<line number>
............................................................................... ...............................................................................
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark" ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark" ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( "aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( "aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( "aardvark" ) ) ) CHECK( spec.matches( *fakeTestCase( "aardvark" ) ) )
with expansion: with expansion:
true true
@ -7337,27 +7337,27 @@ CmdLine.tests.cpp:<line number>
............................................................................... ...............................................................................
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark" ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark" ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( "aardvark " ) ) ) CHECK( spec.matches( *fakeTestCase( "aardvark " ) ) )
with expansion: with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
CHECK( spec.matches( fakeTestCase( "aardvark" ) ) ) CHECK( spec.matches( *fakeTestCase( "aardvark" ) ) )
with expansion: with expansion:
true true
@ -7530,12 +7530,12 @@ with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("notIncluded")) == false ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("notIncluded")) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("test1")) ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("test1")) )
with expansion: with expansion:
true true
@ -7558,12 +7558,12 @@ with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("test1")) == false ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("test1")) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) )
with expansion: with expansion:
true true
@ -7586,12 +7586,12 @@ with expansion:
true true
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("test1")) == false ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("test1")) == false )
with expansion: with expansion:
false == false false == false
CmdLine.tests.cpp:<line number>: PASSED: CmdLine.tests.cpp:<line number>: PASSED:
REQUIRE( cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) ) REQUIRE( cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")) )
with expansion: with expansion:
true true
@ -12341,7 +12341,7 @@ Tag.tests.cpp:<line number>
............................................................................... ...............................................................................
Tag.tests.cpp:<line number>: PASSED: Tag.tests.cpp:<line number>: PASSED:
REQUIRE_THAT( testcase.tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string(".")) ) REQUIRE_THAT( testcase->tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string(".")) )
with expansion: with expansion:
{ ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." ) { ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." )

View File

@ -8031,7 +8031,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8039,7 +8039,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8058,7 +8058,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches(tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8066,7 +8066,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8085,7 +8085,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8093,7 +8093,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8112,7 +8112,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8120,7 +8120,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8139,7 +8139,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8147,7 +8147,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8166,7 +8166,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8174,7 +8174,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8182,7 +8182,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8201,7 +8201,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8209,7 +8209,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8217,7 +8217,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8225,7 +8225,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8233,7 +8233,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
parseTestSpec( "*a" ).matches( tcA ) == true parseTestSpec( "*a" ).matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8252,7 +8252,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8260,7 +8260,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8268,7 +8268,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8276,7 +8276,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8284,7 +8284,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
parseTestSpec( "a*" ).matches( tcA ) == true parseTestSpec( "a*" ).matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8303,7 +8303,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8311,7 +8311,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8319,7 +8319,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8327,7 +8327,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8335,7 +8335,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
parseTestSpec( "*a*" ).matches( tcA ) == true parseTestSpec( "*a*" ).matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8354,7 +8354,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8362,7 +8362,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8381,7 +8381,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8389,7 +8389,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8408,7 +8408,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8416,7 +8416,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8435,7 +8435,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8443,7 +8443,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8451,7 +8451,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8459,7 +8459,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8478,7 +8478,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8486,7 +8486,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8494,7 +8494,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8502,7 +8502,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8521,7 +8521,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8529,7 +8529,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8537,7 +8537,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8556,7 +8556,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8564,7 +8564,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8572,7 +8572,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8591,7 +8591,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8599,7 +8599,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8607,7 +8607,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8626,7 +8626,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8634,7 +8634,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8642,7 +8642,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8661,7 +8661,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8669,7 +8669,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8677,7 +8677,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8685,7 +8685,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8704,7 +8704,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8712,7 +8712,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8720,7 +8720,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8739,7 +8739,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8747,7 +8747,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8755,7 +8755,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8774,7 +8774,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8782,7 +8782,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8790,7 +8790,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8798,7 +8798,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8817,7 +8817,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8825,7 +8825,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8833,7 +8833,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8841,7 +8841,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8860,7 +8860,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8868,7 +8868,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8876,7 +8876,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8884,7 +8884,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8903,7 +8903,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8911,7 +8911,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8919,7 +8919,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8927,7 +8927,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8946,7 +8946,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8954,7 +8954,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8962,7 +8962,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8970,7 +8970,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -8989,7 +8989,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == true spec.matches( *tcA ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -8997,7 +8997,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == true spec.matches( *tcB ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -9005,7 +9005,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -9013,7 +9013,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9032,7 +9032,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9040,7 +9040,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9048,7 +9048,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == true spec.matches( *tcC ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -9056,7 +9056,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9075,7 +9075,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9083,7 +9083,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9091,7 +9091,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9099,7 +9099,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9118,7 +9118,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9126,7 +9126,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9134,7 +9134,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9142,7 +9142,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == false spec.matches( *tcD ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9161,7 +9161,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcA ) == false spec.matches( *tcA ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9169,7 +9169,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcB ) == false spec.matches( *tcB ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9177,7 +9177,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcC ) == false spec.matches( *tcC ) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9185,7 +9185,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( tcD ) == true spec.matches( *tcD ) == true
</Original> </Original>
<Expanded> <Expanded>
true == true true == true
@ -9196,7 +9196,7 @@ Nor would this
<Section name="Leading and trailing spaces in test spec" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Section name="Leading and trailing spaces in test spec" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark " ) ) spec.matches( *fakeTestCase( " aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9204,7 +9204,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark" ) ) spec.matches( *fakeTestCase( " aardvark" ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9212,7 +9212,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark " ) ) spec.matches( *fakeTestCase( " aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9220,7 +9220,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( "aardvark " ) ) spec.matches( *fakeTestCase( "aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9228,7 +9228,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( "aardvark" ) ) spec.matches( *fakeTestCase( "aardvark" ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9239,7 +9239,7 @@ Nor would this
<Section name="Leading and trailing spaces in test name" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Section name="Leading and trailing spaces in test name" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark " ) ) spec.matches( *fakeTestCase( " aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9247,7 +9247,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark" ) ) spec.matches( *fakeTestCase( " aardvark" ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9255,7 +9255,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( " aardvark " ) ) spec.matches( *fakeTestCase( " aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9263,7 +9263,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( "aardvark " ) ) spec.matches( *fakeTestCase( "aardvark " ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9271,7 +9271,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="CHECK" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
spec.matches( fakeTestCase( "aardvark" ) ) spec.matches( *fakeTestCase( "aardvark" ) )
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9499,7 +9499,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("notIncluded")) == false cfg.testSpec().matches(*fakeTestCase("notIncluded")) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9507,7 +9507,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("test1")) cfg.testSpec().matches(*fakeTestCase("test1"))
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9537,7 +9537,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("test1")) == false cfg.testSpec().matches(*fakeTestCase("test1")) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9545,7 +9545,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) cfg.testSpec().matches(*fakeTestCase("alwaysIncluded"))
</Original> </Original>
<Expanded> <Expanded>
true true
@ -9575,7 +9575,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("test1")) == false cfg.testSpec().matches(*fakeTestCase("test1")) == false
</Original> </Original>
<Expanded> <Expanded>
false == false false == false
@ -9583,7 +9583,7 @@ Nor would this
</Expression> </Expression>
<Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" > <Expression success="true" type="REQUIRE" filename="projects/<exe-name>/IntrospectiveTests/CmdLine.tests.cpp" >
<Original> <Original>
cfg.testSpec().matches(fakeTestCase("alwaysIncluded")) cfg.testSpec().matches(*fakeTestCase("alwaysIncluded"))
</Original> </Original>
<Expanded> <Expanded>
true true
@ -14861,7 +14861,7 @@ loose text artifact
<TestCase name="shortened hide tags are split apart" filename="projects/<exe-name>/IntrospectiveTests/Tag.tests.cpp" > <TestCase name="shortened hide tags are split apart" filename="projects/<exe-name>/IntrospectiveTests/Tag.tests.cpp" >
<Expression success="true" type="REQUIRE_THAT" filename="projects/<exe-name>/IntrospectiveTests/Tag.tests.cpp" > <Expression success="true" type="REQUIRE_THAT" filename="projects/<exe-name>/IntrospectiveTests/Tag.tests.cpp" >
<Original> <Original>
testcase.tags, Catch::VectorContains(std::string("magic-tag")) &amp;&amp; Catch::VectorContains(std::string(".")) testcase->tags, Catch::VectorContains(std::string("magic-tag")) &amp;&amp; Catch::VectorContains(std::string("."))
</Original> </Original>
<Expanded> <Expanded>
{ ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." ) { ".", "magic-tag" } ( Contains: "magic-tag" and Contains: "." )

View File

@ -8,6 +8,7 @@
#include "catch.hpp" #include "catch.hpp"
#include "internal/catch_test_spec_parser.h" #include "internal/catch_test_spec_parser.h"
#include "internal/catch_test_case_info.h"
#include "internal/catch_config.hpp" #include "internal/catch_config.hpp"
#include "internal/catch_commandline.h" #include "internal/catch_commandline.h"
@ -15,269 +16,271 @@
# pragma clang diagnostic ignored "-Wc++98-compat" # pragma clang diagnostic ignored "-Wc++98-compat"
#endif #endif
inline Catch::TestCase fakeTestCase(const char* name, const char* desc = "") { return Catch::makeTestCase(nullptr, "", { name, desc }, CATCH_INTERNAL_LINEINFO); } namespace {
auto fakeTestCase(const char* name, const char* desc = "") { return Catch::makeTestCaseInfo("", { name, desc }, CATCH_INTERNAL_LINEINFO); }
}
TEST_CASE( "Parse test names and tags" ) { TEST_CASE( "Parse test names and tags" ) {
using Catch::parseTestSpec; using Catch::parseTestSpec;
using Catch::TestSpec; using Catch::TestSpec;
Catch::TestCase tcA = fakeTestCase( "a" ); auto tcA = fakeTestCase( "a" );
Catch::TestCase tcB = fakeTestCase( "b", "[one][x]" ); auto tcB = fakeTestCase( "b", "[one][x]" );
Catch::TestCase tcC = fakeTestCase( "longer name with spaces", "[two][three][.][x]" ); auto tcC = fakeTestCase( "longer name with spaces", "[two][three][.][x]" );
Catch::TestCase tcD = fakeTestCase( "zlonger name with spacesz" ); auto 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 );
CHECK( spec.matches( tcB ) == true ); CHECK( spec.matches( *tcB ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
CHECK( spec.matches( tcC ) == true ); CHECK( spec.matches( *tcC ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
CHECK( spec.matches( tcC ) == true ); CHECK( spec.matches( *tcC ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
CHECK( spec.matches( tcC ) == true ); CHECK( spec.matches( *tcC ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == true ); CHECK( spec.matches( *tcB ) == true );
CHECK( spec.matches( tcC ) == true ); CHECK( spec.matches( *tcC ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 ) == false ); CHECK( spec.matches( *tcC ) == false );
} }
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
CHECK( spec.matches( tcC ) == false ); CHECK( spec.matches( *tcC ) == false );
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 );
CHECK( spec.matches( tcB ) == true ); CHECK( spec.matches( *tcB ) == true );
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 );
CHECK( spec.matches( tcB ) == true ); CHECK( spec.matches( *tcB ) == true );
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 );
CHECK( spec.matches( tcB ) == true ); CHECK( spec.matches( *tcB ) == true );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
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 );
CHECK( spec.matches( tcB ) == false ); CHECK( spec.matches( *tcB ) == false );
CHECK( spec.matches( tcC ) == false ); CHECK( spec.matches( *tcC ) == false );
CHECK( spec.matches( tcD ) == true ); CHECK( spec.matches( *tcD ) == true );
} }
SECTION( "Leading and trailing spaces in test spec" ) { SECTION( "Leading and trailing spaces in test spec" ) {
TestSpec spec = parseTestSpec( "\" aardvark \"" ); TestSpec spec = parseTestSpec( "\" aardvark \"" );
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( " aardvark" ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark" ) ) );
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( "aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( "aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( "aardvark" ) ) ); CHECK( spec.matches( *fakeTestCase( "aardvark" ) ) );
} }
SECTION( "Leading and trailing spaces in test name" ) { SECTION( "Leading and trailing spaces in test name" ) {
TestSpec spec = parseTestSpec( "aardvark" ); TestSpec spec = parseTestSpec( "aardvark" );
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( " aardvark" ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark" ) ) );
CHECK( spec.matches( fakeTestCase( " aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( " aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( "aardvark " ) ) ); CHECK( spec.matches( *fakeTestCase( "aardvark " ) ) );
CHECK( spec.matches( fakeTestCase( "aardvark" ) ) ); CHECK( spec.matches( *fakeTestCase( "aardvark" ) ) );
} }
} }
@ -317,8 +320,8 @@ TEST_CASE( "Process can be configured on command line", "[config][command-line]"
Catch::Config cfg(config); Catch::Config cfg(config);
REQUIRE(cfg.hasTestFilters()); REQUIRE(cfg.hasTestFilters());
REQUIRE(cfg.testSpec().matches(fakeTestCase("notIncluded")) == false); REQUIRE(cfg.testSpec().matches(*fakeTestCase("notIncluded")) == false);
REQUIRE(cfg.testSpec().matches(fakeTestCase("test1"))); REQUIRE(cfg.testSpec().matches(*fakeTestCase("test1")));
} }
SECTION("Specify one test case exclusion using exclude:") { SECTION("Specify one test case exclusion using exclude:") {
auto result = cli.parse({"test", "exclude:test1"}); auto result = cli.parse({"test", "exclude:test1"});
@ -326,8 +329,8 @@ TEST_CASE( "Process can be configured on command line", "[config][command-line]"
Catch::Config cfg(config); Catch::Config cfg(config);
REQUIRE(cfg.hasTestFilters()); REQUIRE(cfg.hasTestFilters());
REQUIRE(cfg.testSpec().matches(fakeTestCase("test1")) == false); REQUIRE(cfg.testSpec().matches(*fakeTestCase("test1")) == false);
REQUIRE(cfg.testSpec().matches(fakeTestCase("alwaysIncluded"))); REQUIRE(cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")));
} }
SECTION("Specify one test case exclusion using ~") { SECTION("Specify one test case exclusion using ~") {
@ -336,8 +339,8 @@ TEST_CASE( "Process can be configured on command line", "[config][command-line]"
Catch::Config cfg(config); Catch::Config cfg(config);
REQUIRE(cfg.hasTestFilters()); REQUIRE(cfg.hasTestFilters());
REQUIRE(cfg.testSpec().matches(fakeTestCase("test1")) == false); REQUIRE(cfg.testSpec().matches(*fakeTestCase("test1")) == false);
REQUIRE(cfg.testSpec().matches(fakeTestCase("alwaysIncluded"))); REQUIRE(cfg.testSpec().matches(*fakeTestCase("alwaysIncluded")));
} }
} }

View File

@ -42,6 +42,6 @@ TEST_CASE( "Tag alias can be registered against tag patterns" ) {
} }
TEST_CASE("shortened hide tags are split apart") { TEST_CASE("shortened hide tags are split apart") {
auto testcase = Catch::makeTestCase(nullptr, "", {"fake test name", "[.magic-tag]"}, CATCH_INTERNAL_LINEINFO); auto testcase = Catch::makeTestCaseInfo("", {"fake test name", "[.magic-tag]"}, CATCH_INTERNAL_LINEINFO);
REQUIRE_THAT(testcase.tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string("."))); REQUIRE_THAT(testcase->tags, Catch::VectorContains(std::string("magic-tag")) && Catch::VectorContains(std::string(".")));
} }