mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-26 18:25:39 +01:00 
			
		
		
		
	Fixed section ordering issue
If a branch section completes without running any inner sections it will no run subsequent sections (until the next isolated run).
This commit is contained in:
		| @@ -19,6 +19,7 @@ | |||||||
| #include "catch_test_case_info.hpp" | #include "catch_test_case_info.hpp" | ||||||
| #include "catch_capture.hpp" | #include "catch_capture.hpp" | ||||||
| #include "catch_totals.hpp" | #include "catch_totals.hpp" | ||||||
|  | #include "catch_running_test.hpp" | ||||||
|  |  | ||||||
| #include <set> | #include <set> | ||||||
| #include <string> | #include <string> | ||||||
| @@ -57,237 +58,6 @@ namespace Catch | |||||||
|         std::string& m_targetString; |         std::string& m_targetString; | ||||||
|     }; |     }; | ||||||
|      |      | ||||||
|      |  | ||||||
|     /////////////////////////////////////////////////////////////////////////// |  | ||||||
|     ///////////////////////////////////////////////////////////////////////////     |  | ||||||
|     class SectionInfo |  | ||||||
|     { |  | ||||||
|     public: |  | ||||||
|         enum Status |  | ||||||
|         { |  | ||||||
|             Root, |  | ||||||
|             Unknown, |  | ||||||
|             NonLeaf, |  | ||||||
|             TestedLeaf |  | ||||||
|         }; |  | ||||||
|          |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         SectionInfo |  | ||||||
|         ( |  | ||||||
|             SectionInfo* parent |  | ||||||
|         ) |  | ||||||
|         :   m_status( Unknown ), |  | ||||||
|             m_parent( parent ) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         SectionInfo |  | ||||||
|         () |  | ||||||
|         :   m_status( Root ), |  | ||||||
|             m_parent( NULL ) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         ~SectionInfo |  | ||||||
|         () |  | ||||||
|         { |  | ||||||
|             deleteAllValues( m_subSections ); |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         bool shouldRun |  | ||||||
|         () |  | ||||||
|         const |  | ||||||
|         { |  | ||||||
|             return m_status != TestedLeaf; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         bool ran |  | ||||||
|         () |  | ||||||
|         { |  | ||||||
|             if( m_status != NonLeaf ) |  | ||||||
|             { |  | ||||||
|                 m_status = TestedLeaf; |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         SectionInfo* findSubSection |  | ||||||
|         ( |  | ||||||
|             const std::string& name |  | ||||||
|         ) |  | ||||||
|         { |  | ||||||
|             std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.find( name ); |  | ||||||
|             return it != m_subSections.end() |  | ||||||
|                 ? it->second |  | ||||||
|                 : NULL; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         SectionInfo* addSubSection |  | ||||||
|         ( |  | ||||||
|             const std::string& name |  | ||||||
|         ) |  | ||||||
|         { |  | ||||||
|             SectionInfo* subSection = new SectionInfo( this ); |  | ||||||
|             m_subSections.insert( std::make_pair( name, subSection ) ); |  | ||||||
|             m_status = NonLeaf; |  | ||||||
|             return subSection; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         /////////////////////////////////////////////////////////////////////// |  | ||||||
|         SectionInfo* getParent |  | ||||||
|         () |  | ||||||
|         { |  | ||||||
|             return m_parent; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         bool hasUntestedSections |  | ||||||
|         () |  | ||||||
|         const |  | ||||||
|         { |  | ||||||
|             if( m_status == Unknown ) |  | ||||||
|                 return true; |  | ||||||
|              |  | ||||||
|             std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.begin(); |  | ||||||
|             std::map<std::string, SectionInfo*>::const_iterator itEnd = m_subSections.end(); |  | ||||||
|             for(; it != itEnd; ++it ) |  | ||||||
|             { |  | ||||||
|                 if( it->second->hasUntestedSections() ) |  | ||||||
|                     return true; |  | ||||||
|             } |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|      |  | ||||||
|     private: |  | ||||||
|         Status m_status; |  | ||||||
|         std::map<std::string, SectionInfo*> m_subSections; |  | ||||||
|         SectionInfo* m_parent; |  | ||||||
|     }; |  | ||||||
|      |  | ||||||
|     /////////////////////////////////////////////////////////////////////////// |  | ||||||
|     /////////////////////////////////////////////////////////////////////////// |  | ||||||
|  |  | ||||||
|     class RunningTest |  | ||||||
|     { |  | ||||||
|         enum RunStatus |  | ||||||
|         { |  | ||||||
|             NothingRun, |  | ||||||
|             EncounteredASection, |  | ||||||
|             RanAtLeastOneSection, |  | ||||||
|             RanToCompletionWithSections, |  | ||||||
|             RanToCompletionWithNoSections |  | ||||||
|         }; |  | ||||||
|          |  | ||||||
|     public: |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         explicit RunningTest |  | ||||||
|         ( |  | ||||||
|             const TestCaseInfo* info = NULL  |  | ||||||
|         ) |  | ||||||
|         :   m_info( info ), |  | ||||||
|             m_runStatus( RanAtLeastOneSection ), |  | ||||||
|             m_currentSection( &m_rootSection ), |  | ||||||
|             m_changed( false ) |  | ||||||
|         { |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         bool wasSectionSeen |  | ||||||
|         () |  | ||||||
|         const |  | ||||||
|         { |  | ||||||
|             return  m_runStatus == RanAtLeastOneSection ||  |  | ||||||
|                     m_runStatus == RanToCompletionWithSections; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         void reset |  | ||||||
|         () |  | ||||||
|         { |  | ||||||
|             m_runStatus = NothingRun; |  | ||||||
|             m_changed = false; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         void ranToCompletion |  | ||||||
|         () |  | ||||||
|         { |  | ||||||
|             m_runStatus =   m_runStatus == RanAtLeastOneSection || |  | ||||||
|                             m_runStatus == EncounteredASection |  | ||||||
|                 ? RanToCompletionWithSections |  | ||||||
|                 : RanToCompletionWithNoSections; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         bool addSection |  | ||||||
|         ( |  | ||||||
|             const std::string& name |  | ||||||
|         ) |  | ||||||
|         { |  | ||||||
|             if( m_runStatus == NothingRun ) |  | ||||||
|                 m_runStatus = EncounteredASection; |  | ||||||
|              |  | ||||||
|             SectionInfo* thisSection = m_currentSection->findSubSection( name ); |  | ||||||
|             if( !thisSection ) |  | ||||||
|             { |  | ||||||
|                 thisSection = m_currentSection->addSubSection( name ); |  | ||||||
|                 m_changed = true; |  | ||||||
|             } |  | ||||||
|              |  | ||||||
|             if( !wasSectionSeen() && thisSection->shouldRun() ) |  | ||||||
|             { |  | ||||||
|                 m_currentSection = thisSection; |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         void endSection |  | ||||||
|         ( |  | ||||||
|             const std::string& |  | ||||||
|         ) |  | ||||||
|         { |  | ||||||
|             if( m_currentSection->ran() ) |  | ||||||
|             { |  | ||||||
|                 m_runStatus = RanAtLeastOneSection; |  | ||||||
|                 m_changed = true; |  | ||||||
|             } |  | ||||||
|             m_currentSection = m_currentSection->getParent(); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         const TestCaseInfo& getTestCaseInfo |  | ||||||
|         () |  | ||||||
|         const |  | ||||||
|         { |  | ||||||
|             return *m_info; |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|         ///////////////////////////////////////////////////////////////////////         |  | ||||||
|         bool hasUntestedSections |  | ||||||
|         () |  | ||||||
|         const |  | ||||||
|         { |  | ||||||
|             return  m_runStatus == RanAtLeastOneSection || |  | ||||||
|                     ( m_rootSection.hasUntestedSections() && m_changed ); |  | ||||||
|         } |  | ||||||
|          |  | ||||||
|     private: |  | ||||||
|         const TestCaseInfo* m_info; |  | ||||||
|         RunStatus m_runStatus; |  | ||||||
|         SectionInfo m_rootSection; |  | ||||||
|         SectionInfo* m_currentSection; |  | ||||||
|         bool m_changed; |  | ||||||
|     }; |  | ||||||
|      |  | ||||||
|     /////////////////////////////////////////////////////////////////////////// |     /////////////////////////////////////////////////////////////////////////// | ||||||
|     ///////////////////////////////////////////////////////////////////////////     |     ///////////////////////////////////////////////////////////////////////////     | ||||||
|     class Runner : public IResultCapture, public IRunner |     class Runner : public IResultCapture, public IRunner | ||||||
|   | |||||||
							
								
								
									
										150
									
								
								include/internal/catch_running_test.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								include/internal/catch_running_test.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,150 @@ | |||||||
|  | /*   | ||||||
|  |  *  Created by Phil Nash on 4/5/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) | ||||||
|  |  */ | ||||||
|  | #ifndef TWOBLUECUBES_INTERNAL_CATCH_RUNNING_TEST_HPP_INCLUDED | ||||||
|  | #define TWOBLUECUBES_INTERNAL_CATCH_RUNNING_TEST_HPP_INCLUDED | ||||||
|  |  | ||||||
|  | #include "catch_test_case_info.hpp" | ||||||
|  | #include "catch_section_info.hpp" | ||||||
|  |  | ||||||
|  | namespace Catch | ||||||
|  | {     | ||||||
|  |     class RunningTest | ||||||
|  |     { | ||||||
|  |         enum RunStatus | ||||||
|  |         { | ||||||
|  |             NothingRun, | ||||||
|  |             EncounteredASection, | ||||||
|  |             RanAtLeastOneSection, | ||||||
|  |             RanToCompletionWithSections, | ||||||
|  |             RanToCompletionWithNoSections | ||||||
|  |         }; | ||||||
|  |          | ||||||
|  |     public: | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         explicit RunningTest | ||||||
|  |         ( | ||||||
|  |             const TestCaseInfo* info = NULL  | ||||||
|  |         ) | ||||||
|  |         :   m_info( info ), | ||||||
|  |             m_runStatus( RanAtLeastOneSection ), | ||||||
|  |             m_currentSection( &m_rootSection ), | ||||||
|  |             m_changed( false ) | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         bool wasSectionSeen | ||||||
|  |         () | ||||||
|  |         const | ||||||
|  |         { | ||||||
|  |             return  m_runStatus == RanAtLeastOneSection ||  | ||||||
|  |                     m_runStatus == RanToCompletionWithSections; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         void reset | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             m_runStatus = NothingRun; | ||||||
|  |             m_changed = false; | ||||||
|  |             m_lastSectionToRun = NULL; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         void ranToCompletion | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             if( m_runStatus == RanAtLeastOneSection || | ||||||
|  |                 m_runStatus == EncounteredASection ) | ||||||
|  |             { | ||||||
|  |                 m_runStatus = RanToCompletionWithSections; | ||||||
|  |                 if( m_lastSectionToRun ) | ||||||
|  |                 { | ||||||
|  |                     m_lastSectionToRun->ranToCompletion(); | ||||||
|  |                     m_changed = true; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 m_runStatus = RanToCompletionWithNoSections; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         bool addSection | ||||||
|  |         ( | ||||||
|  |             const std::string& name | ||||||
|  |         ) | ||||||
|  |         { | ||||||
|  |             if( m_runStatus == NothingRun ) | ||||||
|  |                 m_runStatus = EncounteredASection; | ||||||
|  |              | ||||||
|  |             SectionInfo* thisSection = m_currentSection->findSubSection( name ); | ||||||
|  |             if( !thisSection ) | ||||||
|  |             { | ||||||
|  |                 thisSection = m_currentSection->addSubSection( name ); | ||||||
|  |                 m_changed = true; | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             if( !wasSectionSeen() && thisSection->shouldRun() ) | ||||||
|  |             { | ||||||
|  |                 m_currentSection = thisSection; | ||||||
|  |                 m_lastSectionToRun = NULL; | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         void endSection | ||||||
|  |         ( | ||||||
|  |             const std::string& | ||||||
|  |         ) | ||||||
|  |         { | ||||||
|  |             if( m_currentSection->ran() ) | ||||||
|  |             { | ||||||
|  |                 m_runStatus = RanAtLeastOneSection; | ||||||
|  |                 m_changed = true; | ||||||
|  |             } | ||||||
|  |             else if( m_runStatus == EncounteredASection ) | ||||||
|  |             { | ||||||
|  |                 m_runStatus = RanAtLeastOneSection; | ||||||
|  |                 m_lastSectionToRun = m_currentSection; | ||||||
|  | //                m_changed = true; | ||||||
|  |             } | ||||||
|  |             m_currentSection = m_currentSection->getParent(); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         const TestCaseInfo& getTestCaseInfo | ||||||
|  |         () | ||||||
|  |         const | ||||||
|  |         { | ||||||
|  |             return *m_info; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         bool hasUntestedSections | ||||||
|  |         () | ||||||
|  |         const | ||||||
|  |         { | ||||||
|  |             return  m_runStatus == RanAtLeastOneSection || | ||||||
|  |                     ( m_rootSection.hasUntestedSections() && m_changed ); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |     private: | ||||||
|  |         const TestCaseInfo* m_info; | ||||||
|  |         RunStatus m_runStatus; | ||||||
|  |         SectionInfo m_rootSection; | ||||||
|  |         SectionInfo* m_currentSection; | ||||||
|  |         SectionInfo* m_lastSectionToRun; | ||||||
|  |         bool m_changed; | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif // TWOBLUECUBES_INTERNAL_CATCH_RUNNING_TEST_HPP_INCLUDED | ||||||
							
								
								
									
										142
									
								
								include/internal/catch_section_info.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								include/internal/catch_section_info.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,142 @@ | |||||||
|  | /*   | ||||||
|  |  *  Created by Phil Nash on 4/5/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) | ||||||
|  |  */ | ||||||
|  | #ifndef TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED | ||||||
|  | #define TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED | ||||||
|  |  | ||||||
|  | #include "catch_common.h" | ||||||
|  |  | ||||||
|  | #include <map> | ||||||
|  | #include <string> | ||||||
|  |  | ||||||
|  | namespace Catch | ||||||
|  | {     | ||||||
|  |     /////////////////////////////////////////////////////////////////////////// | ||||||
|  |     ///////////////////////////////////////////////////////////////////////////     | ||||||
|  |     class SectionInfo | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |         enum Status | ||||||
|  |         { | ||||||
|  |             Root, | ||||||
|  |             Unknown, | ||||||
|  |             Branch, | ||||||
|  |             TestedBranch, | ||||||
|  |             TestedLeaf | ||||||
|  |         }; | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         SectionInfo | ||||||
|  |         ( | ||||||
|  |             SectionInfo* parent | ||||||
|  |         ) | ||||||
|  |         :   m_status( Unknown ), | ||||||
|  |             m_parent( parent ) | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         SectionInfo | ||||||
|  |         () | ||||||
|  |         :   m_status( Root ), | ||||||
|  |             m_parent( NULL ) | ||||||
|  |         { | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         ~SectionInfo | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             deleteAllValues( m_subSections ); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         bool shouldRun | ||||||
|  |         () | ||||||
|  |         const | ||||||
|  |         { | ||||||
|  |             return m_status < TestedBranch; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         bool ran | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             if( m_status < Branch ) | ||||||
|  |             { | ||||||
|  |                 m_status = TestedLeaf; | ||||||
|  |                 return true; | ||||||
|  |             }             | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         void ranToCompletion | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             if( m_status == Branch && !hasUntestedSections() ) | ||||||
|  |             { | ||||||
|  |                 m_status = TestedBranch; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |                  | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         SectionInfo* findSubSection | ||||||
|  |         ( | ||||||
|  |             const std::string& name | ||||||
|  |         ) | ||||||
|  |         { | ||||||
|  |             std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.find( name ); | ||||||
|  |             return it != m_subSections.end() | ||||||
|  |                         ? it->second | ||||||
|  |                         : NULL; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         SectionInfo* addSubSection | ||||||
|  |         ( | ||||||
|  |             const std::string& name | ||||||
|  |         ) | ||||||
|  |         { | ||||||
|  |             SectionInfo* subSection = new SectionInfo( this ); | ||||||
|  |             m_subSections.insert( std::make_pair( name, subSection ) ); | ||||||
|  |             m_status = Branch; | ||||||
|  |             return subSection; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         /////////////////////////////////////////////////////////////////////// | ||||||
|  |         SectionInfo* getParent | ||||||
|  |         () | ||||||
|  |         { | ||||||
|  |             return m_parent; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         ///////////////////////////////////////////////////////////////////////         | ||||||
|  |         bool hasUntestedSections | ||||||
|  |         () | ||||||
|  |         const | ||||||
|  |         { | ||||||
|  |             if( m_status == Unknown ) | ||||||
|  |                 return true; | ||||||
|  |              | ||||||
|  |             std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.begin(); | ||||||
|  |             std::map<std::string, SectionInfo*>::const_iterator itEnd = m_subSections.end(); | ||||||
|  |             for(; it != itEnd; ++it ) | ||||||
|  |             { | ||||||
|  |                 if( it->second->hasUntestedSections() ) | ||||||
|  |                     return true; | ||||||
|  |             } | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |     private: | ||||||
|  |         Status m_status; | ||||||
|  |         std::map<std::string, SectionInfo*> m_subSections; | ||||||
|  |         SectionInfo* m_parent; | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif // TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED | ||||||
| @@ -18,7 +18,6 @@ | |||||||
| #include <set> | #include <set> | ||||||
| #include <sstream> | #include <sstream> | ||||||
|  |  | ||||||
| #include <iostream> // !TBD DBG |  | ||||||
| namespace Catch | namespace Catch | ||||||
| { | { | ||||||
|     class TestRegistry : public ITestCaseRegistry |     class TestRegistry : public ITestCaseRegistry | ||||||
|   | |||||||
| @@ -96,26 +96,33 @@ TEST_CASE( "Sections/nested3", "nested SECTION tests" ) | |||||||
|      |      | ||||||
|     runner.runMatching( "./Sections/nested/a/b", "mock" ); |     runner.runMatching( "./Sections/nested/a/b", "mock" ); | ||||||
|     CHECK( runner.getLog() ==  |     CHECK( runner.getLog() ==  | ||||||
|         "[tc]( ./Sections/nested/a/b ){ " |         "\\[tc] ./Sections/nested/a/b\n" | ||||||
|          |          | ||||||
|           "[g]( test case run ){  " |         " \\[g] test case run\n" | ||||||
|             "[s]( c ){  " |         "  \\ [s] c\n" | ||||||
|                 "[s]( d (leaf) ){  }  [s]( d (leaf) ) " |         "   \\ [s] d (leaf)\n" | ||||||
|             "}  [s]( c ) " |         "   / [s] d (leaf)\n" | ||||||
|           "} [g]( test case run )" |         "  / [s] c\n" | ||||||
|  |         " /[g] test case run\n" | ||||||
|          |          | ||||||
|           "[g]( test case run ){  " |         " \\[g] test case run\n" | ||||||
|             "[s]( c ){  " |         "  \\ [s] c\n" | ||||||
|                 "[s]( e (leaf) ){  }  [s]( e (leaf) ) " |         "   \\ [s] e (leaf)\n" | ||||||
|             "}  [s]( c ) " |         "   / [s] e (leaf)\n" | ||||||
|           "} [g]( test case run )" |         "  / [s] c\n" | ||||||
|  |         " /[g] test case run\n" | ||||||
|          |          | ||||||
|           "[g]( test case run ){  " |         " \\[g] test case run\n" | ||||||
|             "[s]( c ){  }  [s]( c ) " |         "  \\ [s] c\n" | ||||||
|             "[s]( f (leaf) ){  }  [s]( f (leaf) ) " |         "  / [s] c\n" | ||||||
|           "} [g]( test case run ) " |         " /[g] test case run\n" | ||||||
|          |          | ||||||
|         "} [tc]( ./Sections/nested/a/b )" ); |         " \\[g] test case run\n" | ||||||
|  |         "  \\ [s] f (leaf)\n" | ||||||
|  |         "  / [s] f (leaf)\n" | ||||||
|  |         " /[g] test case run\n" | ||||||
|  |          | ||||||
|  |         "/[tc] ./Sections/nested/a/b\n" ); | ||||||
|      |      | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -95,8 +95,7 @@ namespace Catch | |||||||
|             const std::string& groupName |             const std::string& groupName | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordGroups ) ) |             openLabel( recordGroups, groupName ); | ||||||
|                 m_log << recordGroups << "( " << groupName << " ){ "; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void EndGroup |         virtual void EndGroup | ||||||
| @@ -105,8 +104,7 @@ namespace Catch | |||||||
|             const Totals& totals |             const Totals& totals | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordGroups ) ) |             closeLabel( recordGroups, groupName ); | ||||||
|                 m_log << " } " << recordGroups << "( " << groupName << " )"; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void StartSection |         virtual void StartSection | ||||||
| @@ -115,8 +113,7 @@ namespace Catch | |||||||
|             const std::string description  |             const std::string description  | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordSections ) ) |             openLabel( recordSections, sectionName ); | ||||||
|                 m_log << recordSections << "( " << sectionName << " ){ "; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void EndSection |         virtual void EndSection | ||||||
| @@ -125,8 +122,7 @@ namespace Catch | |||||||
|             const Counts& assertions  |             const Counts& assertions  | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordSections ) ) |             closeLabel( recordSections, sectionName ); | ||||||
|                 m_log << " } " << recordSections << "( " << sectionName << " )"; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void StartTestCase |         virtual void StartTestCase | ||||||
| @@ -134,8 +130,7 @@ namespace Catch | |||||||
|             const TestCaseInfo& testInfo  |             const TestCaseInfo& testInfo  | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordTestCases ) ) |             openLabel( recordTestCases, testInfo.getName()  ); | ||||||
|                 m_log << recordTestCases << "( " << testInfo.getName() << " ){ "; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void EndTestCase |         virtual void EndTestCase | ||||||
| @@ -146,8 +141,7 @@ namespace Catch | |||||||
|             const std::string& stdErr  |             const std::string& stdErr  | ||||||
|         ) |         ) | ||||||
|         { |         { | ||||||
|             if( shouldRecord( recordTestCases ) ) |             closeLabel( recordTestCases, testInfo.getName()  ); | ||||||
|                 m_log << " } " << recordTestCases << "( " << testInfo.getName() << " )"; |  | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         virtual void Result |         virtual void Result | ||||||
| @@ -214,6 +208,32 @@ namespace Catch | |||||||
|         { |         { | ||||||
|             return m_recorders.find( recorder ) != m_recorders.end(); |             return m_recorders.find( recorder ) != m_recorders.end(); | ||||||
|         } |         } | ||||||
|  |          | ||||||
|  |         void openLabel( const std::string& label, const std::string& arg = "" ) | ||||||
|  |         { | ||||||
|  |             if( shouldRecord( label ) ) | ||||||
|  |             { | ||||||
|  |                 m_log << m_indent << "\\" << label; | ||||||
|  |                 if( !arg.empty() ) | ||||||
|  |                     m_log << " " << arg; | ||||||
|  |                 m_log << "\n"; | ||||||
|  |                 m_indent += " "; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         void closeLabel( const std::string& label, const std::string& arg = "" ) | ||||||
|  |         { | ||||||
|  |             if( shouldRecord( label ) ) | ||||||
|  |             { | ||||||
|  |                 m_indent = m_indent.substr( 0, m_indent.size()-1 ); | ||||||
|  |                 m_log << m_indent << "/" << label; | ||||||
|  |                 if( !arg.empty() ) | ||||||
|  |                     m_log << " " << arg; | ||||||
|  |                 m_log << "\n"; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         std::string m_indent; | ||||||
|         std::ostringstream m_log; |         std::ostringstream m_log; | ||||||
|         std::set<std::string> m_recorders; |         std::set<std::string> m_recorders; | ||||||
|     };     |     };     | ||||||
|   | |||||||
| @@ -88,6 +88,8 @@ | |||||||
| 		4AB1C73514F97BDA00F31DF7 /* catch_console_colour_impl.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_console_colour_impl.hpp; sourceTree = "<group>"; }; | 		4AB1C73514F97BDA00F31DF7 /* catch_console_colour_impl.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_console_colour_impl.hpp; sourceTree = "<group>"; }; | ||||||
| 		4AB1C73714F97C1300F31DF7 /* catch_console_colour.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_console_colour.hpp; sourceTree = "<group>"; }; | 		4AB1C73714F97C1300F31DF7 /* catch_console_colour.hpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.h; path = catch_console_colour.hpp; sourceTree = "<group>"; }; | ||||||
| 		4AB77CB51551AEA200857BF0 /* catch_ptr.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_ptr.hpp; sourceTree = "<group>"; }; | 		4AB77CB51551AEA200857BF0 /* catch_ptr.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_ptr.hpp; sourceTree = "<group>"; }; | ||||||
|  | 		4AB77CB71553B72B00857BF0 /* catch_section_info.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = catch_section_info.hpp; sourceTree = "<group>"; }; | ||||||
|  | 		4AB77CB81553BB3800857BF0 /* catch_running_test.hpp */ = {isa = PBXFileReference; path = catch_running_test.hpp; sourceTree = "<group>"; }; | ||||||
| 		4AE1840A14EE4F230066340D /* catch_self_test.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_self_test.cpp; path = ../../../SelfTest/catch_self_test.cpp; sourceTree = "<group>"; }; | 		4AE1840A14EE4F230066340D /* catch_self_test.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = catch_self_test.cpp; path = ../../../SelfTest/catch_self_test.cpp; sourceTree = "<group>"; }; | ||||||
| /* End PBXFileReference section */ | /* End PBXFileReference section */ | ||||||
|  |  | ||||||
| @@ -197,6 +199,8 @@ | |||||||
| 				4AB1C73714F97C1300F31DF7 /* catch_console_colour.hpp */, | 				4AB1C73714F97C1300F31DF7 /* catch_console_colour.hpp */, | ||||||
| 				4A3D7DD01503869D005F9203 /* catch_matchers.hpp */, | 				4A3D7DD01503869D005F9203 /* catch_matchers.hpp */, | ||||||
| 				4AB77CB51551AEA200857BF0 /* catch_ptr.hpp */, | 				4AB77CB51551AEA200857BF0 /* catch_ptr.hpp */, | ||||||
|  | 				4AB77CB71553B72B00857BF0 /* catch_section_info.hpp */, | ||||||
|  | 				4AB77CB81553BB3800857BF0 /* catch_running_test.hpp */, | ||||||
| 			); | 			); | ||||||
| 			name = internal; | 			name = internal; | ||||||
| 			path = ../../../../include/internal; | 			path = ../../../../include/internal; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Phil Nash
					Phil Nash