mirror of
https://github.com/catchorg/Catch2.git
synced 2024-12-23 11:43:29 +01:00
Catch and register startup exceptions in autoregistrars
Previously they were registered where they would be thrown otherwise
This commit is contained in:
parent
da0edcbe25
commit
860de28b8d
@ -39,29 +39,13 @@ namespace Catch {
|
||||
}
|
||||
|
||||
void TagAliasRegistry::add( std::string const& alias, std::string const& tag, SourceLineInfo const& lineInfo ) {
|
||||
// Do not throw when constructing global objects, instead register the exception to be processed later
|
||||
if (!(startsWith( alias, "[@") && endsWith(alias, ']'))) {
|
||||
getMutableRegistryHub().registerStartupException(
|
||||
std::make_exception_ptr(
|
||||
CATCH_PREPARE_EXCEPTION( std::domain_error,
|
||||
"error: tag alias, '"
|
||||
<< alias
|
||||
<< "' is not of the form [@alias name].\n"
|
||||
<< lineInfo)
|
||||
)
|
||||
);
|
||||
}
|
||||
CATCH_ENFORCE( startsWith(alias, "[@") && endsWith(alias, ']'),
|
||||
"error: tag alias, '" << alias << "' is not of the form [@alias name].\n" << lineInfo );
|
||||
|
||||
if (!m_registry.insert(std::make_pair(alias, TagAlias(tag, lineInfo))).second) {
|
||||
getMutableRegistryHub().registerStartupException(
|
||||
std::make_exception_ptr(
|
||||
CATCH_PREPARE_EXCEPTION(std::domain_error,
|
||||
"error: tag alias, '" << alias << "' already registered.\n"
|
||||
<< "\tFirst seen at: " << find(alias)->lineInfo << "\n"
|
||||
<< "\tRedefined at: " << lineInfo)
|
||||
)
|
||||
);
|
||||
}
|
||||
CATCH_ENFORCE( m_registry.insert(std::make_pair(alias, TagAlias(tag, lineInfo))).second,
|
||||
"error: tag alias, '" << alias << "' already registered.\n"
|
||||
<< "\tFirst seen at: " << find(alias)->lineInfo << "\n"
|
||||
<< "\tRedefined at: " << lineInfo );
|
||||
}
|
||||
|
||||
ITagAliasRegistry::~ITagAliasRegistry() {}
|
||||
@ -71,7 +55,12 @@ namespace Catch {
|
||||
}
|
||||
|
||||
RegistrarForTagAliases::RegistrarForTagAliases( char const* alias, char const* tag, SourceLineInfo const& lineInfo ) {
|
||||
getMutableRegistryHub().registerTagAlias( alias, tag, lineInfo );
|
||||
try {
|
||||
getMutableRegistryHub().registerTagAlias(alias, tag, lineInfo);
|
||||
} catch (...) {
|
||||
// Do not throw when constructing global objects, instead register the exception to be processed later
|
||||
getMutableRegistryHub().registerStartupException(std::current_exception());
|
||||
}
|
||||
}
|
||||
|
||||
} // end namespace Catch
|
||||
|
@ -38,16 +38,10 @@ namespace Catch {
|
||||
return parseSpecialTag( tag ) == TestCaseInfo::None && tag.size() > 0 && !std::isalnum( tag[0] );
|
||||
}
|
||||
inline void enforceNotReservedTag( std::string const& tag, SourceLineInfo const& _lineInfo ) {
|
||||
// Do not throw when constructing global objects, instead register the exception to be processed later
|
||||
if (isReservedTag(tag)) {
|
||||
getMutableRegistryHub().registerStartupException(
|
||||
std::make_exception_ptr(
|
||||
CATCH_PREPARE_EXCEPTION(std::domain_error, "Tag name: [" << tag << "] is not allowed.\n"
|
||||
<< "Tag names starting with non alpha-numeric characters are reserved\n"
|
||||
<< _lineInfo)
|
||||
)
|
||||
);
|
||||
}
|
||||
CATCH_ENFORCE( !isReservedTag(tag),
|
||||
"Tag name: [" << tag << "] is not allowed.\n"
|
||||
<< "Tag names starting with non alpha-numeric characters are reserved\n"
|
||||
<< _lineInfo );
|
||||
}
|
||||
|
||||
TestCase makeTestCase( ITestCase* _testCase,
|
||||
|
@ -154,14 +154,18 @@ namespace Catch {
|
||||
char const* classOrQualifiedMethodName,
|
||||
NameAndDesc const& nameAndDesc,
|
||||
SourceLineInfo const& lineInfo ) {
|
||||
|
||||
getMutableRegistryHub().registerTest
|
||||
( makeTestCase
|
||||
( testCase,
|
||||
extractClassName( classOrQualifiedMethodName ),
|
||||
nameAndDesc.name,
|
||||
nameAndDesc.description,
|
||||
lineInfo ) );
|
||||
try {
|
||||
getMutableRegistryHub().registerTest
|
||||
(makeTestCase
|
||||
(testCase,
|
||||
extractClassName(classOrQualifiedMethodName),
|
||||
nameAndDesc.name,
|
||||
nameAndDesc.description,
|
||||
lineInfo));
|
||||
} catch (...) {
|
||||
// Do not throw when constructing global objects, instead register the exception to be processed later
|
||||
getMutableRegistryHub().registerStartupException( std::current_exception() );
|
||||
}
|
||||
}
|
||||
void registerTestCaseFunction
|
||||
( TestFunction function,
|
||||
|
Loading…
Reference in New Issue
Block a user