mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-24 18:35:38 +02:00 
			
		
		
		
	Stop checking verbosities up-front
This commit is contained in:
		| @@ -29,18 +29,6 @@ method will be removed. | |||||||
|  |  | ||||||
| ## Planned changes | ## Planned changes | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Reporter verbosities |  | ||||||
|  |  | ||||||
| The current implementation of verbosities, where the reporter is checked |  | ||||||
| up-front whether it supports the requested verbosity, is fundamentally |  | ||||||
| misguided and will be changed. The new implementation will no longer check |  | ||||||
| whether the specified reporter supports the requested verbosity, instead |  | ||||||
| it will be up to the reporters to deal with verbosities as they see fit |  | ||||||
| (with an expectation that unsupported verbosities will be, at most, |  | ||||||
| warnings, but not errors). |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### Output format of `--list-*` command line parameters | ### Output format of `--list-*` command line parameters | ||||||
|  |  | ||||||
| The various list operations will be piped through reporters. This means | The various list operations will be piped through reporters. This means | ||||||
|   | |||||||
| @@ -208,7 +208,6 @@ namespace Catch { | |||||||
|  |  | ||||||
|         // Implementing class must also provide the following static methods: |         // Implementing class must also provide the following static methods: | ||||||
|         // static std::string getDescription(); |         // static std::string getDescription(); | ||||||
|         // static std::set<Verbosity> getSupportedVerbosities() |  | ||||||
|  |  | ||||||
|         virtual ReporterPreferences getPreferences() const = 0; |         virtual ReporterPreferences getPreferences() const = 0; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -59,10 +59,6 @@ namespace Catch { | |||||||
|     TestEventListenerBase::TestEventListenerBase(ReporterConfig const & _config) |     TestEventListenerBase::TestEventListenerBase(ReporterConfig const & _config) | ||||||
|         :StreamingReporterBase(_config) {} |         :StreamingReporterBase(_config) {} | ||||||
|  |  | ||||||
|     std::set<Verbosity> TestEventListenerBase::getSupportedVerbosities() { |  | ||||||
|         return { Verbosity::Quiet, Verbosity::Normal, Verbosity::High }; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void TestEventListenerBase::assertionStarting(AssertionInfo const &) {} |     void TestEventListenerBase::assertionStarting(AssertionInfo const &) {} | ||||||
|  |  | ||||||
|     bool TestEventListenerBase::assertionEnded(AssertionStats const &) { |     bool TestEventListenerBase::assertionEnded(AssertionStats const &) { | ||||||
|   | |||||||
| @@ -35,18 +35,12 @@ namespace Catch { | |||||||
|             stream( _config.stream() ) |             stream( _config.stream() ) | ||||||
|         { |         { | ||||||
|             m_reporterPrefs.shouldRedirectStdOut = false; |             m_reporterPrefs.shouldRedirectStdOut = false; | ||||||
|             if( !DerivedT::getSupportedVerbosities().count( m_config->verbosity() ) ) |  | ||||||
|                 CATCH_ERROR( "Verbosity level not supported by this reporter" ); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ReporterPreferences getPreferences() const override { |         ReporterPreferences getPreferences() const override { | ||||||
|             return m_reporterPrefs; |             return m_reporterPrefs; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         static std::set<Verbosity> getSupportedVerbosities() { |  | ||||||
|             return { Verbosity::Normal }; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ~StreamingReporterBase() override = default; |         ~StreamingReporterBase() override = default; | ||||||
|  |  | ||||||
|         void noMatchingTestCases(std::string const&) override {} |         void noMatchingTestCases(std::string const&) override {} | ||||||
| @@ -153,8 +147,6 @@ namespace Catch { | |||||||
|             stream( _config.stream() ) |             stream( _config.stream() ) | ||||||
|         { |         { | ||||||
|             m_reporterPrefs.shouldRedirectStdOut = false; |             m_reporterPrefs.shouldRedirectStdOut = false; | ||||||
|             if( !DerivedT::getSupportedVerbosities().count( m_config->verbosity() ) ) |  | ||||||
|                 CATCH_ERROR( "Verbosity level not supported by this reporter" ); |  | ||||||
|         } |         } | ||||||
|         ~CumulativeReporterBase() override = default; |         ~CumulativeReporterBase() override = default; | ||||||
|  |  | ||||||
| @@ -162,10 +154,6 @@ namespace Catch { | |||||||
|             return m_reporterPrefs; |             return m_reporterPrefs; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         static std::set<Verbosity> getSupportedVerbosities() { |  | ||||||
|             return { Verbosity::Normal }; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         void testRunStarting( TestRunInfo const& ) override {} |         void testRunStarting( TestRunInfo const& ) override {} | ||||||
|         void testGroupStarting( GroupInfo const& ) override {} |         void testGroupStarting( GroupInfo const& ) override {} | ||||||
|  |  | ||||||
| @@ -271,8 +259,6 @@ namespace Catch { | |||||||
|     struct TestEventListenerBase : StreamingReporterBase<TestEventListenerBase> { |     struct TestEventListenerBase : StreamingReporterBase<TestEventListenerBase> { | ||||||
|         TestEventListenerBase( ReporterConfig const& _config ); |         TestEventListenerBase( ReporterConfig const& _config ); | ||||||
|  |  | ||||||
|         static std::set<Verbosity> getSupportedVerbosities(); |  | ||||||
|  |  | ||||||
|         void assertionStarting(AssertionInfo const&) override; |         void assertionStarting(AssertionInfo const&) override; | ||||||
|         bool assertionEnded(AssertionStats const&) override; |         bool assertionEnded(AssertionStats const&) override; | ||||||
|     }; |     }; | ||||||
|   | |||||||
| @@ -30,11 +30,6 @@ namespace Catch { | |||||||
|         return m_preferences; |         return m_preferences; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     std::set<Verbosity> ListeningReporter::getSupportedVerbosities() { |  | ||||||
|         return std::set<Verbosity>{ }; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     void ListeningReporter::noMatchingTestCases( std::string const& spec ) { |     void ListeningReporter::noMatchingTestCases( std::string const& spec ) { | ||||||
|         for ( auto const& listener : m_listeners ) { |         for ( auto const& listener : m_listeners ) { | ||||||
|             listener->noMatchingTestCases( spec ); |             listener->noMatchingTestCases( spec ); | ||||||
|   | |||||||
| @@ -31,8 +31,6 @@ namespace Catch { | |||||||
|  |  | ||||||
|         void reportInvalidArguments(std::string const&arg) override; |         void reportInvalidArguments(std::string const&arg) override; | ||||||
|  |  | ||||||
|         static std::set<Verbosity> getSupportedVerbosities(); |  | ||||||
|  |  | ||||||
| #if defined(CATCH_CONFIG_ENABLE_BENCHMARKING) | #if defined(CATCH_CONFIG_ENABLE_BENCHMARKING) | ||||||
|         void benchmarkPreparing(std::string const& name) override; |         void benchmarkPreparing(std::string const& name) override; | ||||||
|         void benchmarkStarting( BenchmarkInfo const& benchmarkInfo ) override; |         void benchmarkStarting( BenchmarkInfo const& benchmarkInfo ) override; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Martin Hořeňovský
					Martin Hořeňovský