mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-29 16:53:30 +01:00
First cut of tags support
This commit is contained in:
parent
dea756f699
commit
fc1baac7f5
@ -35,7 +35,6 @@ namespace Catch {
|
|||||||
std::vector<TestCaseFilters> filterGroups = m_config.filters;
|
std::vector<TestCaseFilters> filterGroups = m_config.filters;
|
||||||
if( filterGroups.empty() ) {
|
if( filterGroups.empty() ) {
|
||||||
TestCaseFilters filterGroup( "" );
|
TestCaseFilters filterGroup( "" );
|
||||||
filterGroup.addFilter( TestCaseFilter( "./*", IfFilterMatches::ExcludeTests ) );
|
|
||||||
filterGroups.push_back( filterGroup );
|
filterGroups.push_back( filterGroup );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "catch_common.h"
|
#include "catch_common.h"
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <set>
|
||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
@ -34,6 +35,8 @@ namespace Catch {
|
|||||||
const std::string& getDescription() const;
|
const std::string& getDescription() const;
|
||||||
const SourceLineInfo& getLineInfo() const;
|
const SourceLineInfo& getLineInfo() const;
|
||||||
bool isHidden() const;
|
bool isHidden() const;
|
||||||
|
bool hasTag( const std::string& tag ) const;
|
||||||
|
const std::set<std::string>& tags() const;
|
||||||
|
|
||||||
void swap( TestCaseInfo& other );
|
void swap( TestCaseInfo& other );
|
||||||
bool operator == ( const TestCaseInfo& other ) const;
|
bool operator == ( const TestCaseInfo& other ) const;
|
||||||
@ -44,6 +47,7 @@ namespace Catch {
|
|||||||
Ptr<ITestCase> m_test;
|
Ptr<ITestCase> m_test;
|
||||||
std::string m_name;
|
std::string m_name;
|
||||||
std::string m_description;
|
std::string m_description;
|
||||||
|
std::set<std::string> m_tags;
|
||||||
SourceLineInfo m_lineInfo;
|
SourceLineInfo m_lineInfo;
|
||||||
bool m_isHidden;
|
bool m_isHidden;
|
||||||
};
|
};
|
||||||
|
@ -13,6 +13,36 @@
|
|||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
void extractTags( std::string& str, std::set<std::string>& tags ) {
|
||||||
|
std::string remainder;
|
||||||
|
std::size_t last = 0;
|
||||||
|
std::size_t begin = str.find_first_of( '[' );
|
||||||
|
while( begin != std::string::npos ) {
|
||||||
|
std::size_t end = str.find_first_of( ']', begin );
|
||||||
|
if( end != std::string::npos ) {
|
||||||
|
std::string tag = str.substr( begin+1, end-begin-1 );
|
||||||
|
tags.insert( tag );
|
||||||
|
if( begin - last > 0 )
|
||||||
|
remainder += str.substr( last, begin-last );
|
||||||
|
last = end+1;
|
||||||
|
}
|
||||||
|
else if( begin != str.size()-1 ) {
|
||||||
|
end = begin+1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
begin = str.find_first_of( '[', end );
|
||||||
|
}
|
||||||
|
if( !tags.empty() ) {
|
||||||
|
if( last < str.size() )
|
||||||
|
str = remainder + str.substr( last );
|
||||||
|
else
|
||||||
|
str = remainder;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
TestCaseInfo::TestCaseInfo( ITestCase* testCase,
|
TestCaseInfo::TestCaseInfo( ITestCase* testCase,
|
||||||
const char* name,
|
const char* name,
|
||||||
const char* description,
|
const char* description,
|
||||||
@ -22,7 +52,11 @@ namespace Catch {
|
|||||||
m_description( description ),
|
m_description( description ),
|
||||||
m_lineInfo( lineInfo ),
|
m_lineInfo( lineInfo ),
|
||||||
m_isHidden( startsWith( name, "./" ) )
|
m_isHidden( startsWith( name, "./" ) )
|
||||||
{}
|
{
|
||||||
|
extractTags( m_description, m_tags );
|
||||||
|
if( hasTag( "hide" ) )
|
||||||
|
m_isHidden = true;
|
||||||
|
}
|
||||||
|
|
||||||
TestCaseInfo::TestCaseInfo()
|
TestCaseInfo::TestCaseInfo()
|
||||||
: m_test( NULL ),
|
: m_test( NULL ),
|
||||||
@ -35,6 +69,7 @@ namespace Catch {
|
|||||||
: m_test( other.m_test ),
|
: m_test( other.m_test ),
|
||||||
m_name( name ),
|
m_name( name ),
|
||||||
m_description( other.m_description ),
|
m_description( other.m_description ),
|
||||||
|
m_tags( other.m_tags ),
|
||||||
m_lineInfo( other.m_lineInfo ),
|
m_lineInfo( other.m_lineInfo ),
|
||||||
m_isHidden( other.m_isHidden )
|
m_isHidden( other.m_isHidden )
|
||||||
{}
|
{}
|
||||||
@ -43,6 +78,7 @@ namespace Catch {
|
|||||||
: m_test( other.m_test ),
|
: m_test( other.m_test ),
|
||||||
m_name( other.m_name ),
|
m_name( other.m_name ),
|
||||||
m_description( other.m_description ),
|
m_description( other.m_description ),
|
||||||
|
m_tags( other.m_tags ),
|
||||||
m_lineInfo( other.m_lineInfo ),
|
m_lineInfo( other.m_lineInfo ),
|
||||||
m_isHidden( other.m_isHidden )
|
m_isHidden( other.m_isHidden )
|
||||||
{}
|
{}
|
||||||
@ -67,6 +103,13 @@ namespace Catch {
|
|||||||
return m_isHidden;
|
return m_isHidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool TestCaseInfo::hasTag( const std::string& tag ) const {
|
||||||
|
return m_tags.find( tag ) != m_tags.end();
|
||||||
|
}
|
||||||
|
const std::set<std::string>& TestCaseInfo::tags() const {
|
||||||
|
return m_tags;
|
||||||
|
}
|
||||||
|
|
||||||
void TestCaseInfo::swap( TestCaseInfo& other ) {
|
void TestCaseInfo::swap( TestCaseInfo& other ) {
|
||||||
m_test.swap( other.m_test );
|
m_test.swap( other.m_test );
|
||||||
m_name.swap( other.m_name );
|
m_name.swap( other.m_name );
|
||||||
|
@ -123,6 +123,10 @@ namespace Catch {
|
|||||||
if( it == itEnd )
|
if( it == itEnd )
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
else if( m_exclusionFilters.empty() ) {
|
||||||
|
return !testCase.isHidden();
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<TestCaseFilter>::const_iterator it = m_exclusionFilters.begin();
|
std::vector<TestCaseFilter>::const_iterator it = m_exclusionFilters.begin();
|
||||||
std::vector<TestCaseFilter>::const_iterator itEnd = m_exclusionFilters.end();
|
std::vector<TestCaseFilter>::const_iterator itEnd = m_exclusionFilters.end();
|
||||||
for(; it != itEnd; ++it )
|
for(; it != itEnd; ++it )
|
||||||
|
@ -293,3 +293,8 @@ TEST_CASE( "example/factorial", "The Factorial function should return the factor
|
|||||||
TEST_CASE( "empty", "An empty test with no assertions" )
|
TEST_CASE( "empty", "An empty test with no assertions" )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_CASE( "Nice descriptive name", "[tag1][tag2][hide]" )
|
||||||
|
{
|
||||||
|
WARN( "This one ran" );
|
||||||
|
}
|
||||||
|
@ -330,7 +330,52 @@ TEST_CASE( "selftest/option parsers", "" )
|
|||||||
REQUIRE( config.filters.size() == 1 );
|
REQUIRE( config.filters.size() == 1 );
|
||||||
REQUIRE( config.filters[0].shouldInclude( makeTestCase( "notIncluded" ) ) == false );
|
REQUIRE( config.filters[0].shouldInclude( makeTestCase( "notIncluded" ) ) == false );
|
||||||
REQUIRE( config.filters[0].shouldInclude( makeTestCase( "test1" ) ) );
|
REQUIRE( config.filters[0].shouldInclude( makeTestCase( "test1" ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE( "selftest/tags", "" ) {
|
||||||
|
|
||||||
|
SECTION( "one tag", "" ) {
|
||||||
|
Catch::TestCaseInfo oneTag( NULL, "test", "[one]", CATCH_INTERNAL_LINEINFO );
|
||||||
|
|
||||||
|
CHECK( oneTag.getDescription() == "" );
|
||||||
|
CHECK( oneTag.hasTag( "one" ) );
|
||||||
|
CHECK( oneTag.tags().size() == 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION( "two tags", "" ) {
|
||||||
|
Catch::TestCaseInfo twoTags( NULL, "test", "[one][two]", CATCH_INTERNAL_LINEINFO );
|
||||||
|
|
||||||
|
CHECK( twoTags.getDescription() == "" );
|
||||||
|
CHECK( twoTags.hasTag( "one" ) );
|
||||||
|
CHECK( twoTags.hasTag( "two" ) );
|
||||||
|
CHECK( twoTags.hasTag( "three" ) == false );
|
||||||
|
CHECK( twoTags.tags().size() == 2 );
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION( "one tag with characters either side", "" ) {
|
||||||
|
|
||||||
|
Catch::TestCaseInfo oneTagWithExtras( NULL, "test", "12[one]34", CATCH_INTERNAL_LINEINFO );
|
||||||
|
CHECK( oneTagWithExtras.getDescription() == "1234" );
|
||||||
|
CHECK( oneTagWithExtras.hasTag( "one" ) );
|
||||||
|
CHECK( oneTagWithExtras.hasTag( "two" ) == false );
|
||||||
|
CHECK( oneTagWithExtras.tags().size() == 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION( "start of a tag, but not closed", "" ) {
|
||||||
|
|
||||||
|
Catch::TestCaseInfo oneTagOpen( NULL, "test", "[one", CATCH_INTERNAL_LINEINFO );
|
||||||
|
|
||||||
|
CHECK( oneTagOpen.getDescription() == "[one" );
|
||||||
|
CHECK( oneTagOpen.hasTag( "one" ) == false );
|
||||||
|
CHECK( oneTagOpen.tags().size() == 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION( "hidden", "" ) {
|
||||||
|
Catch::TestCaseInfo oneTag( NULL, "test", "[hide]", CATCH_INTERNAL_LINEINFO );
|
||||||
|
|
||||||
|
CHECK( oneTag.getDescription() == "" );
|
||||||
|
CHECK( oneTag.hasTag( "hide" ) );
|
||||||
|
CHECK( oneTag.isHidden() );
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Generated: 2012-09-09 11:44:01.394438
|
* Generated: 2012-09-15 17:50:31.695760
|
||||||
* ----------------------------------------------------------
|
* ----------------------------------------------------------
|
||||||
* This file has been merged from multiple headers. Please don't edit it directly
|
* This file has been merged from multiple headers. Please don't edit it directly
|
||||||
* Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved.
|
* Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved.
|
||||||
@ -1644,6 +1644,7 @@ using namespace Generators;
|
|||||||
#define TWOBLUECUBES_CATCH_TESTCASEINFO_H_INCLUDED
|
#define TWOBLUECUBES_CATCH_TESTCASEINFO_H_INCLUDED
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <set>
|
||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
@ -1666,6 +1667,8 @@ namespace Catch {
|
|||||||
const std::string& getDescription() const;
|
const std::string& getDescription() const;
|
||||||
const SourceLineInfo& getLineInfo() const;
|
const SourceLineInfo& getLineInfo() const;
|
||||||
bool isHidden() const;
|
bool isHidden() const;
|
||||||
|
bool hasTag( const std::string& tag ) const;
|
||||||
|
const std::set<std::string>& tags() const;
|
||||||
|
|
||||||
void swap( TestCaseInfo& other );
|
void swap( TestCaseInfo& other );
|
||||||
bool operator == ( const TestCaseInfo& other ) const;
|
bool operator == ( const TestCaseInfo& other ) const;
|
||||||
@ -1676,7 +1679,9 @@ namespace Catch {
|
|||||||
Ptr<ITestCase> m_test;
|
Ptr<ITestCase> m_test;
|
||||||
std::string m_name;
|
std::string m_name;
|
||||||
std::string m_description;
|
std::string m_description;
|
||||||
|
std::set<std::string> m_tags;
|
||||||
SourceLineInfo m_lineInfo;
|
SourceLineInfo m_lineInfo;
|
||||||
|
bool m_isHidden;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1793,6 +1798,10 @@ namespace Catch {
|
|||||||
if( it == itEnd )
|
if( it == itEnd )
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
else if( m_exclusionFilters.empty() ) {
|
||||||
|
return !testCase.isHidden();
|
||||||
|
}
|
||||||
|
|
||||||
std::vector<TestCaseFilter>::const_iterator it = m_exclusionFilters.begin();
|
std::vector<TestCaseFilter>::const_iterator it = m_exclusionFilters.begin();
|
||||||
std::vector<TestCaseFilter>::const_iterator itEnd = m_exclusionFilters.end();
|
std::vector<TestCaseFilter>::const_iterator itEnd = m_exclusionFilters.end();
|
||||||
for(; it != itEnd; ++it )
|
for(; it != itEnd; ++it )
|
||||||
@ -3697,7 +3706,6 @@ namespace Catch {
|
|||||||
std::vector<TestCaseFilters> filterGroups = m_config.filters;
|
std::vector<TestCaseFilters> filterGroups = m_config.filters;
|
||||||
if( filterGroups.empty() ) {
|
if( filterGroups.empty() ) {
|
||||||
TestCaseFilters filterGroup( "" );
|
TestCaseFilters filterGroup( "" );
|
||||||
filterGroup.addFilter( TestCaseFilter( "./*", IfFilterMatches::ExcludeTests ) );
|
|
||||||
filterGroups.push_back( filterGroup );
|
filterGroups.push_back( filterGroup );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4738,6 +4746,36 @@ namespace Catch {
|
|||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
void extractTags( std::string& str, std::set<std::string>& tags ) {
|
||||||
|
std::string remainder;
|
||||||
|
std::size_t last = 0;
|
||||||
|
std::size_t begin = str.find_first_of( '[' );
|
||||||
|
while( begin != std::string::npos ) {
|
||||||
|
std::size_t end = str.find_first_of( ']', begin );
|
||||||
|
if( end != std::string::npos ) {
|
||||||
|
std::string tag = str.substr( begin+1, end-begin-1 );
|
||||||
|
tags.insert( tag );
|
||||||
|
if( begin - last > 0 )
|
||||||
|
remainder += str.substr( last, begin-last );
|
||||||
|
last = end+1;
|
||||||
|
}
|
||||||
|
else if( begin != str.size()-1 ) {
|
||||||
|
end = begin+1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
begin = str.find_first_of( '[', end );
|
||||||
|
}
|
||||||
|
if( !tags.empty() ) {
|
||||||
|
if( last < str.size() )
|
||||||
|
str = remainder + str.substr( last );
|
||||||
|
else
|
||||||
|
str = remainder;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
TestCaseInfo::TestCaseInfo( ITestCase* testCase,
|
TestCaseInfo::TestCaseInfo( ITestCase* testCase,
|
||||||
const char* name,
|
const char* name,
|
||||||
const char* description,
|
const char* description,
|
||||||
@ -4745,27 +4783,37 @@ namespace Catch {
|
|||||||
: m_test( testCase ),
|
: m_test( testCase ),
|
||||||
m_name( name ),
|
m_name( name ),
|
||||||
m_description( description ),
|
m_description( description ),
|
||||||
m_lineInfo( lineInfo )
|
m_lineInfo( lineInfo ),
|
||||||
{}
|
m_isHidden( startsWith( name, "./" ) )
|
||||||
|
{
|
||||||
|
extractTags( m_description, m_tags );
|
||||||
|
if( hasTag( "hide" ) )
|
||||||
|
m_isHidden = true;
|
||||||
|
}
|
||||||
|
|
||||||
TestCaseInfo::TestCaseInfo()
|
TestCaseInfo::TestCaseInfo()
|
||||||
: m_test( NULL ),
|
: m_test( NULL ),
|
||||||
m_name(),
|
m_name(),
|
||||||
m_description()
|
m_description(),
|
||||||
|
m_isHidden( false )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
TestCaseInfo::TestCaseInfo( const TestCaseInfo& other, const std::string& name )
|
TestCaseInfo::TestCaseInfo( const TestCaseInfo& other, const std::string& name )
|
||||||
: m_test( other.m_test ),
|
: m_test( other.m_test ),
|
||||||
m_name( name ),
|
m_name( name ),
|
||||||
m_description( other.m_description ),
|
m_description( other.m_description ),
|
||||||
m_lineInfo( other.m_lineInfo )
|
m_tags( other.m_tags ),
|
||||||
|
m_lineInfo( other.m_lineInfo ),
|
||||||
|
m_isHidden( other.m_isHidden )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
TestCaseInfo::TestCaseInfo( const TestCaseInfo& other )
|
TestCaseInfo::TestCaseInfo( const TestCaseInfo& other )
|
||||||
: m_test( other.m_test ),
|
: m_test( other.m_test ),
|
||||||
m_name( other.m_name ),
|
m_name( other.m_name ),
|
||||||
m_description( other.m_description ),
|
m_description( other.m_description ),
|
||||||
m_lineInfo( other.m_lineInfo )
|
m_tags( other.m_tags ),
|
||||||
|
m_lineInfo( other.m_lineInfo ),
|
||||||
|
m_isHidden( other.m_isHidden )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
void TestCaseInfo::invoke() const {
|
void TestCaseInfo::invoke() const {
|
||||||
@ -4785,7 +4833,14 @@ namespace Catch {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool TestCaseInfo::isHidden() const {
|
bool TestCaseInfo::isHidden() const {
|
||||||
return m_name.size() >= 2 && m_name[0] == '.' && m_name[1] == '/';
|
return m_isHidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool TestCaseInfo::hasTag( const std::string& tag ) const {
|
||||||
|
return m_tags.find( tag ) != m_tags.end();
|
||||||
|
}
|
||||||
|
const std::set<std::string>& TestCaseInfo::tags() const {
|
||||||
|
return m_tags;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestCaseInfo::swap( TestCaseInfo& other ) {
|
void TestCaseInfo::swap( TestCaseInfo& other ) {
|
||||||
|
Loading…
Reference in New Issue
Block a user