mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-25 23:06:10 +01:00
Make reporter lookup case insensitive, registration case preserving
Previously registration was case preserving, but lookup used lowercased reporter name, so a reporter whose name contained upper case character could not be requested by the user.
This commit is contained in:
parent
7800fe9708
commit
8780425385
@ -177,6 +177,8 @@ new design.
|
|||||||
* Various ways of failing a benchmark are now counted and reporter properly
|
* Various ways of failing a benchmark are now counted and reporter properly
|
||||||
* The ULP matcher now handles comparing numbers with different signs properly (#2152)
|
* The ULP matcher now handles comparing numbers with different signs properly (#2152)
|
||||||
* Universal ADL-found operators should no longer break decomposition (#2121)
|
* Universal ADL-found operators should no longer break decomposition (#2121)
|
||||||
|
* Reporter selection is properly case-insensitive
|
||||||
|
* Previously it forced lower cased name, which would fail for reporters with upper case characters in name
|
||||||
|
|
||||||
|
|
||||||
### Other changes
|
### Other changes
|
||||||
|
@ -76,8 +76,21 @@ namespace Catch {
|
|||||||
|
|
||||||
|
|
||||||
#include <catch2/interfaces/catch_interfaces_reporter_registry.hpp>
|
#include <catch2/interfaces/catch_interfaces_reporter_registry.hpp>
|
||||||
|
#include <catch2/internal/catch_string_manip.hpp>
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
namespace Catch {
|
namespace Catch {
|
||||||
|
|
||||||
IReporterRegistry::~IReporterRegistry() = default;
|
IReporterRegistry::~IReporterRegistry() = default;
|
||||||
|
bool IReporterRegistry::CaseInsensitiveCmp::operator()(std::string const& lhs, std::string const& rhs) const {
|
||||||
|
return std::lexicographical_compare(lhs.begin(), lhs.end(),
|
||||||
|
rhs.begin(), rhs.end(),
|
||||||
|
[](char l, char r) {
|
||||||
|
return toLower(l) < toLower(r);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -24,7 +24,11 @@ namespace Catch {
|
|||||||
using IReporterFactoryPtr = Detail::unique_ptr<IReporterFactory>;
|
using IReporterFactoryPtr = Detail::unique_ptr<IReporterFactory>;
|
||||||
|
|
||||||
struct IReporterRegistry {
|
struct IReporterRegistry {
|
||||||
using FactoryMap = std::map<std::string, IReporterFactoryPtr>;
|
struct CaseInsensitiveCmp {
|
||||||
|
bool operator()(std::string const& lhs, std::string const& rhs) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
using FactoryMap = std::map<std::string, IReporterFactoryPtr, CaseInsensitiveCmp>;
|
||||||
using Listeners = std::vector<IReporterFactoryPtr>;
|
using Listeners = std::vector<IReporterFactoryPtr>;
|
||||||
|
|
||||||
virtual ~IReporterRegistry(); // = default
|
virtual ~IReporterRegistry(); // = default
|
||||||
|
@ -140,11 +140,10 @@ namespace Catch {
|
|||||||
auto const setReporter = [&]( std::string const& reporter ) {
|
auto const setReporter = [&]( std::string const& reporter ) {
|
||||||
IReporterRegistry::FactoryMap const& factories = getRegistryHub().getReporterRegistry().getFactories();
|
IReporterRegistry::FactoryMap const& factories = getRegistryHub().getReporterRegistry().getFactories();
|
||||||
|
|
||||||
auto lcReporter = toLower( reporter );
|
auto result = factories.find( reporter );
|
||||||
auto result = factories.find( lcReporter );
|
|
||||||
|
|
||||||
if( factories.end() != result )
|
if( factories.end() != result )
|
||||||
config.reporterName = lcReporter;
|
config.reporterName = reporter;
|
||||||
else
|
else
|
||||||
return ParserResult::runtimeError( "Unrecognized reporter, '" + reporter + "'. Check available with --list-reporters" );
|
return ParserResult::runtimeError( "Unrecognized reporter, '" + reporter + "'. Check available with --list-reporters" );
|
||||||
return ParserResult::ok( ParseResultType::Matched );
|
return ParserResult::ok( ParseResultType::Matched );
|
||||||
|
@ -197,6 +197,28 @@ add_test(
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
add_executable(CasingInReporterNames ${TESTS_DIR}/X23-CasingInReporterNames.cpp)
|
||||||
|
target_link_libraries(CasingInReporterNames PRIVATE Catch2::Catch2WithMain)
|
||||||
|
add_test(
|
||||||
|
NAME Reporters::registration-is-case-preserving
|
||||||
|
COMMAND CasingInReporterNames --list-reporters
|
||||||
|
)
|
||||||
|
set_tests_properties(
|
||||||
|
Reporters::registration-is-case-preserving
|
||||||
|
PROPERTIES
|
||||||
|
PASS_REGULAR_EXPRESSION "testReporterCASED"
|
||||||
|
)
|
||||||
|
add_test(
|
||||||
|
NAME Reporters::selection-is-case-insensitive
|
||||||
|
COMMAND CasingInReporterNames -r testReportercased
|
||||||
|
)
|
||||||
|
set_tests_properties(
|
||||||
|
Reporters::selection-is-case-insensitive
|
||||||
|
PROPERTIES
|
||||||
|
PASS_REGULAR_EXPRESSION "TestReporter constructed"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
add_executable(DuplicatedTestCases-SameNameAndTags ${TESTS_DIR}/X31-DuplicatedTestCases.cpp)
|
add_executable(DuplicatedTestCases-SameNameAndTags ${TESTS_DIR}/X31-DuplicatedTestCases.cpp)
|
||||||
target_link_libraries(DuplicatedTestCases-SameNameAndTags PRIVATE Catch2::Catch2WithMain)
|
target_link_libraries(DuplicatedTestCases-SameNameAndTags PRIVATE Catch2::Catch2WithMain)
|
||||||
add_test(
|
add_test(
|
||||||
|
40
tests/ExtraTests/X23-CasingInReporterNames.cpp
Normal file
40
tests/ExtraTests/X23-CasingInReporterNames.cpp
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
|
||||||
|
// Copyright Catch2 Authors
|
||||||
|
// Distributed under the Boost Software License, Version 1.0.
|
||||||
|
// (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
// https://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
// SPDX-License-Identifier: BSL-1.0
|
||||||
|
|
||||||
|
/**\file
|
||||||
|
* Test that reporter registration is case-preserving, selection is
|
||||||
|
* case-insensitive.
|
||||||
|
*
|
||||||
|
* This is done by registering a custom reporter that prints out a marker
|
||||||
|
* string upon construction and then invoking the binary with different
|
||||||
|
* casings of the name.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <catch2/reporters/catch_reporter_streaming_base.hpp>
|
||||||
|
#include <catch2/catch_reporter_registrars.hpp>
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
class TestReporter : public Catch::StreamingReporterBase {
|
||||||
|
public:
|
||||||
|
TestReporter(Catch::ReporterConfig const& _config):
|
||||||
|
StreamingReporterBase(_config) {
|
||||||
|
std::cout << "TestReporter constructed\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::string getDescription() {
|
||||||
|
return "Reporter for testing casing handling in reporter registration/selection";
|
||||||
|
}
|
||||||
|
|
||||||
|
~TestReporter() override;
|
||||||
|
};
|
||||||
|
|
||||||
|
TestReporter::~TestReporter() = default;
|
||||||
|
|
||||||
|
CATCH_REGISTER_REPORTER("testReporterCASED", TestReporter)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user