mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-31 20:27:11 +01:00 
			
		
		
		
	Split imll from TestCaseInfo
This commit is contained in:
		| @@ -20,6 +20,7 @@ | ||||
| #include "catch_generators_impl.hpp" | ||||
| #include "catch_resultinfo.hpp" | ||||
| #include "catch_resultinfo_builder.hpp" | ||||
| #include "catch_test_case_info.hpp" | ||||
|  | ||||
| namespace Catch { | ||||
|     NonCopyable::~NonCopyable() {} | ||||
|   | ||||
| @@ -17,7 +17,7 @@ | ||||
| // NB. Any general catch headers included here must be included | ||||
| // in catch.hpp first to make sure they are included by the single | ||||
| // header for non obj-usage | ||||
| #include "internal/catch_test_case_info.hpp" | ||||
| #include "internal/catch_test_case_info.h" | ||||
|  | ||||
| /////////////////////////////////////////////////////////////////////////////// | ||||
| // This protocol is really only here for (self) documenting purposes, since | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
| #include "catch_interfaces_exception.h" | ||||
| #include "catch_config.hpp" | ||||
| #include "catch_test_registry.hpp" | ||||
| #include "catch_test_case_info.hpp" | ||||
| #include "catch_test_case_info.h" | ||||
| #include "catch_capture.hpp" | ||||
| #include "catch_totals.hpp" | ||||
| #include "catch_running_test.hpp" | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
| #ifndef TWOBLUECUBES_INTERNAL_CATCH_RUNNING_TEST_HPP_INCLUDED | ||||
| #define TWOBLUECUBES_INTERNAL_CATCH_RUNNING_TEST_HPP_INCLUDED | ||||
|  | ||||
| #include "catch_test_case_info.hpp" | ||||
| #include "catch_test_case_info.h" | ||||
| #include "catch_section_info.hpp" | ||||
|  | ||||
| namespace Catch { | ||||
|   | ||||
							
								
								
									
										75
									
								
								include/internal/catch_test_case_info.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								include/internal/catch_test_case_info.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| /* | ||||
|  *  Created by Phil on 29/10/2010. | ||||
|  *  Copyright 2010 Two Blue Cubes Ltd. All rights reserved. | ||||
|  * | ||||
|  *  Distributed under the Boost Software License, Version 1.0. (See accompanying | ||||
|  *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | ||||
|  */ | ||||
| #ifndef TWOBLUECUBES_CATCH_TESTCASEINFO_H_INCLUDED | ||||
| #define TWOBLUECUBES_CATCH_TESTCASEINFO_H_INCLUDED | ||||
|  | ||||
| #include "catch_common.h" | ||||
|  | ||||
| #include <string> | ||||
|  | ||||
| namespace Catch { | ||||
|  | ||||
|     struct ITestCase; | ||||
|  | ||||
|     class TestCaseInfo { | ||||
|     public: | ||||
|         TestCaseInfo(); | ||||
|  | ||||
|         TestCaseInfo(   ITestCase* testCase, | ||||
|                         const char* name,  | ||||
|                         const char* description, | ||||
|                         const SourceLineInfo& lineInfo ); | ||||
|  | ||||
|  | ||||
|         TestCaseInfo( const TestCaseInfo& other, const std::string& name ); | ||||
|  | ||||
|         void invoke() const; | ||||
|         const std::string& getName() const; | ||||
|         const std::string& getDescription() const; | ||||
|         const SourceLineInfo& getLineInfo() const; | ||||
|         bool isHidden() const; | ||||
|          | ||||
|         void swap( TestCaseInfo& other ); | ||||
|         bool operator == ( const TestCaseInfo& other ) const; | ||||
|         bool operator < ( const TestCaseInfo& other ) const; | ||||
|  | ||||
|     private: | ||||
|         Ptr<ITestCase> m_test; | ||||
|         std::string m_name; | ||||
|         std::string m_description; | ||||
|         SourceLineInfo m_lineInfo;         | ||||
|     }; | ||||
|      | ||||
|     ///////////////////////////////////////////////////////////////////////////     | ||||
|      | ||||
|     class TestSpec { | ||||
|     public: | ||||
|         TestSpec( const std::string& rawSpec ) | ||||
|         :   m_rawSpec( rawSpec ), | ||||
|             m_isWildcarded( false ) { | ||||
|              | ||||
|             if( m_rawSpec[m_rawSpec.size()-1] == '*' ) { | ||||
|                 m_rawSpec = m_rawSpec.substr( 0, m_rawSpec.size()-1 ); | ||||
|                 m_isWildcarded = true; | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         bool matches ( const std::string& testName ) const { | ||||
|             if( !m_isWildcarded ) | ||||
|                 return m_rawSpec == testName; | ||||
|             else | ||||
|                 return testName.size() >= m_rawSpec.size() && testName.substr( 0, m_rawSpec.size() ) == m_rawSpec;             | ||||
|         } | ||||
|          | ||||
|     private: | ||||
|         std::string m_rawSpec; | ||||
|         bool m_isWildcarded; | ||||
|     }; | ||||
| } | ||||
|  | ||||
| #endif // TWOBLUECUBES_CATCH_TESTCASEINFO_H_INCLUDED | ||||
| @@ -1,6 +1,6 @@ | ||||
| /* | ||||
|  *  Created by Phil on 29/10/2010. | ||||
|  *  Copyright 2010 Two Blue Cubes Ltd. All rights reserved. | ||||
|  *  Created by Phil on 14/08/2012. | ||||
|  *  Copyright 2012 Two Blue Cubes Ltd. All rights reserved. | ||||
|  * | ||||
|  *  Distributed under the Boost Software License, Version 1.0. (See accompanying | ||||
|  *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | ||||
| @@ -8,105 +8,68 @@ | ||||
| #ifndef TWOBLUECUBES_CATCH_TESTCASEINFO_HPP_INCLUDED | ||||
| #define TWOBLUECUBES_CATCH_TESTCASEINFO_HPP_INCLUDED | ||||
|  | ||||
| #include "catch_common.h" | ||||
| #include "catch_test_case_info.h" | ||||
| #include "catch_interfaces_testcase.h" | ||||
| #include <map> | ||||
| #include <string> | ||||
|  | ||||
| namespace Catch { | ||||
|  | ||||
|     class TestCaseInfo { | ||||
|     public: | ||||
|         TestCaseInfo(   ITestCase* testCase,  | ||||
|                         const char* name,  | ||||
|                         const char* description, | ||||
|                         const SourceLineInfo& lineInfo ) | ||||
|         :   m_test( testCase ), | ||||
|             m_name( name ), | ||||
|             m_description( description ), | ||||
|             m_lineInfo( lineInfo ) | ||||
|         {} | ||||
|     TestCaseInfo::TestCaseInfo( ITestCase* testCase, | ||||
|                                 const char* name, | ||||
|                                 const char* description, | ||||
|                                 const SourceLineInfo& lineInfo ) | ||||
|     :   m_test( testCase ), | ||||
|         m_name( name ), | ||||
|         m_description( description ), | ||||
|         m_lineInfo( lineInfo ) | ||||
|     {} | ||||
|  | ||||
|         TestCaseInfo()  | ||||
|         :   m_test( NULL ), | ||||
|             m_name(), | ||||
|             m_description() | ||||
|         {} | ||||
|          | ||||
|         TestCaseInfo( const TestCaseInfo& other, const std::string& name ) | ||||
|         :   m_test( other.m_test ), | ||||
|             m_name( name ), | ||||
|             m_description( other.m_description ), | ||||
|             m_lineInfo( other.m_lineInfo ) | ||||
|         {} | ||||
|     TestCaseInfo::TestCaseInfo() | ||||
|     :   m_test( NULL ), | ||||
|         m_name(), | ||||
|         m_description() | ||||
|     {} | ||||
|  | ||||
|         void invoke() const { | ||||
|             m_test->invoke(); | ||||
|         } | ||||
|          | ||||
|         const std::string& getName() const { | ||||
|             return m_name; | ||||
|         } | ||||
|     TestCaseInfo::TestCaseInfo( const TestCaseInfo& other, const std::string& name ) | ||||
|     :   m_test( other.m_test ), | ||||
|         m_name( name ), | ||||
|         m_description( other.m_description ), | ||||
|         m_lineInfo( other.m_lineInfo ) | ||||
|     {} | ||||
|  | ||||
|         const std::string& getDescription() const { | ||||
|             return m_description; | ||||
|         } | ||||
|     void TestCaseInfo::invoke() const { | ||||
|         m_test->invoke(); | ||||
|     } | ||||
|  | ||||
|         const SourceLineInfo& getLineInfo() const { | ||||
|             return m_lineInfo; | ||||
|         } | ||||
|     const std::string& TestCaseInfo::getName() const { | ||||
|         return m_name; | ||||
|     } | ||||
|  | ||||
|         bool isHidden() const { | ||||
|             return m_name.size() >= 2 && m_name[0] == '.' && m_name[1] == '/'; | ||||
|         }         | ||||
|          | ||||
|         void swap( TestCaseInfo& other ) { | ||||
|             m_test.swap( other.m_test ); | ||||
|             m_name.swap( other.m_name ); | ||||
|             m_description.swap( other.m_description ); | ||||
|             m_lineInfo.swap( other.m_lineInfo ); | ||||
|         } | ||||
|          | ||||
|         bool operator == ( const TestCaseInfo& other ) const { | ||||
|             return m_test.get() == other.m_test.get() && m_name == other.m_name; | ||||
|         } | ||||
|          | ||||
|         bool operator < ( const TestCaseInfo& other ) const { | ||||
|             return m_name < other.m_name; | ||||
|         } | ||||
|     const std::string& TestCaseInfo::getDescription() const { | ||||
|         return m_description; | ||||
|     } | ||||
|  | ||||
|     private: | ||||
|         Ptr<ITestCase> m_test; | ||||
|         std::string m_name; | ||||
|         std::string m_description; | ||||
|         SourceLineInfo m_lineInfo;         | ||||
|     }; | ||||
|      | ||||
|     ///////////////////////////////////////////////////////////////////////////     | ||||
|      | ||||
|     class TestSpec { | ||||
|     public: | ||||
|         TestSpec( const std::string& rawSpec ) | ||||
|         :   m_rawSpec( rawSpec ), | ||||
|             m_isWildcarded( false ) { | ||||
|              | ||||
|             if( m_rawSpec[m_rawSpec.size()-1] == '*' ) { | ||||
|                 m_rawSpec = m_rawSpec.substr( 0, m_rawSpec.size()-1 ); | ||||
|                 m_isWildcarded = true; | ||||
|             } | ||||
|         } | ||||
|          | ||||
|         bool matches ( const std::string& testName ) const { | ||||
|             if( !m_isWildcarded ) | ||||
|                 return m_rawSpec == testName; | ||||
|             else | ||||
|                 return testName.size() >= m_rawSpec.size() && testName.substr( 0, m_rawSpec.size() ) == m_rawSpec;             | ||||
|         } | ||||
|          | ||||
|     private: | ||||
|         std::string m_rawSpec; | ||||
|         bool m_isWildcarded; | ||||
|     }; | ||||
|     const SourceLineInfo& TestCaseInfo::getLineInfo() const { | ||||
|         return m_lineInfo; | ||||
|     } | ||||
|  | ||||
|     bool TestCaseInfo::isHidden() const { | ||||
|         return m_name.size() >= 2 && m_name[0] == '.' && m_name[1] == '/'; | ||||
|     } | ||||
|  | ||||
|     void TestCaseInfo::swap( TestCaseInfo& other ) { | ||||
|         m_test.swap( other.m_test ); | ||||
|         m_name.swap( other.m_name ); | ||||
|         m_description.swap( other.m_description ); | ||||
|         m_lineInfo.swap( other.m_lineInfo ); | ||||
|     } | ||||
|  | ||||
|     bool TestCaseInfo::operator == ( const TestCaseInfo& other ) const { | ||||
|         return m_test.get() == other.m_test.get() && m_name == other.m_name; | ||||
|     } | ||||
|  | ||||
|     bool TestCaseInfo::operator < ( const TestCaseInfo& other ) const { | ||||
|         return m_name < other.m_name; | ||||
|     } | ||||
| } | ||||
|  | ||||
| #endif // TWOBLUECUBES_CATCH_TESTCASEINFO_HPP_INCLUDED | ||||
|   | ||||
| @@ -6,7 +6,7 @@ | ||||
|  *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | ||||
|  */ | ||||
| #include "catch_test_registry.hpp" | ||||
| #include "catch_test_case_info.hpp" | ||||
| #include "catch_test_case_info.h" | ||||
| #include "catch_context.h" | ||||
|  | ||||
| #include <vector> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Phil Nash
					Phil Nash