mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-11-04 05:59:32 +01:00 
			
		
		
		
	Multiple tests can have same name as long as their tags differ
This change also changes it so that test case macros using a class name can have same name **and** tags as long as the used class name differs. Closes #1915 Closes #1999
This commit is contained in:
		@@ -180,6 +180,55 @@ add_test(
 | 
			
		||||
  COMMAND ${PYTHON_EXECUTABLE} ${CATCH_DIR}/tests/TestScripts/testPartialTestCaseEvent.py $<TARGET_FILE:PartialTestCaseEvents>
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
add_executable(DuplicatedTestCases-SameNameAndTags ${TESTS_DIR}/X31-DuplicatedTestCases.cpp)
 | 
			
		||||
target_link_libraries(DuplicatedTestCases-SameNameAndTags PRIVATE Catch2::Catch2WithMain)
 | 
			
		||||
add_test(
 | 
			
		||||
  NAME DuplicatedTestCases::SameNameAndTags
 | 
			
		||||
  COMMAND $<TARGET_FILE:DuplicatedTestCases-SameNameAndTags>
 | 
			
		||||
)
 | 
			
		||||
set_tests_properties(
 | 
			
		||||
    DuplicatedTestCases::SameNameAndTags
 | 
			
		||||
  PROPERTIES
 | 
			
		||||
     PASS_REGULAR_EXPRESSION "error: .* already defined\\."
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
add_executable(DuplicatedTestCases-SameNameDifferentTags ${TESTS_DIR}/X32-DuplicatedTestCasesDifferentTags.cpp)
 | 
			
		||||
target_link_libraries(DuplicatedTestCases-SameNameDifferentTags PRIVATE Catch2::Catch2WithMain)
 | 
			
		||||
add_test(
 | 
			
		||||
  NAME DuplicatedTestCases::SameNameDifferentTags
 | 
			
		||||
  COMMAND $<TARGET_FILE:DuplicatedTestCases-SameNameDifferentTags>
 | 
			
		||||
)
 | 
			
		||||
set_tests_properties(
 | 
			
		||||
    DuplicatedTestCases::SameNameDifferentTags
 | 
			
		||||
  PROPERTIES
 | 
			
		||||
     FAIL_REGULAR_EXPRESSION "error: .* already defined\\."
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
add_executable(DuplicatedTestCases-DuplicatedTestCaseMethods ${TESTS_DIR}/X33-DuplicatedTestCaseMethods.cpp)
 | 
			
		||||
target_link_libraries(DuplicatedTestCases-DuplicatedTestCaseMethods PRIVATE Catch2::Catch2WithMain)
 | 
			
		||||
add_test(
 | 
			
		||||
  NAME DuplicatedTestCases::DuplicatedTestCaseMethods
 | 
			
		||||
  COMMAND $<TARGET_FILE:DuplicatedTestCases-DuplicatedTestCaseMethods>
 | 
			
		||||
)
 | 
			
		||||
set_tests_properties(
 | 
			
		||||
    DuplicatedTestCases::DuplicatedTestCaseMethods
 | 
			
		||||
  PROPERTIES
 | 
			
		||||
     PASS_REGULAR_EXPRESSION "error: .* already defined\\."
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
add_executable(DuplicatedTestCases-DifferentFixtures ${TESTS_DIR}/X34-DuplicatedTestCaseMethodsDifferentFixtures.cpp)
 | 
			
		||||
target_link_libraries(DuplicatedTestCases-DifferentFixtures PRIVATE Catch2::Catch2WithMain)
 | 
			
		||||
add_test(
 | 
			
		||||
  NAME DuplicatedTestCases::DuplicatedTestCaseMethodsDifferentFixtures
 | 
			
		||||
  COMMAND $<TARGET_FILE:DuplicatedTestCases-DifferentFixtures>
 | 
			
		||||
)
 | 
			
		||||
set_tests_properties(
 | 
			
		||||
    DuplicatedTestCases::DuplicatedTestCaseMethodsDifferentFixtures
 | 
			
		||||
  PROPERTIES
 | 
			
		||||
    FAIL_REGULAR_EXPRESSION "error: .* already defined\\."
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
#add_executable(DebugBreakMacros ${TESTS_DIR}/X12-CustomDebugBreakMacro.cpp)
 | 
			
		||||
#target_link_libraries(DebugBreakMacros Catch2)
 | 
			
		||||
#add_test(NAME DebugBreakMacros COMMAND DebugBreakMacros --break)
 | 
			
		||||
@@ -196,6 +245,10 @@ set( EXTRA_TEST_BINARIES
 | 
			
		||||
    DisabledExceptions-CustomHandler
 | 
			
		||||
    FallbackStringifier
 | 
			
		||||
    DisableStringification
 | 
			
		||||
    PartialTestCaseEvents
 | 
			
		||||
    DuplicatedTestCases-SameNameAndTags
 | 
			
		||||
    DuplicatedTestCases-SameNameDifferentTags
 | 
			
		||||
    DuplicatedTestCases-DuplicatedTestCaseMethods
 | 
			
		||||
#    DebugBreakMacros
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										16
									
								
								tests/ExtraTests/X31-DuplicatedTestCases.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								tests/ExtraTests/X31-DuplicatedTestCases.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,16 @@
 | 
			
		||||
 | 
			
		||||
//              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
 | 
			
		||||
 * Checks that test cases with identical name and tags are reported as error
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <catch2/catch_test_macros.hpp>
 | 
			
		||||
 | 
			
		||||
TEST_CASE("A test case with duplicated name and tags", "[tag1][tag2]") {}
 | 
			
		||||
TEST_CASE("A test case with duplicated name and tags", "[tag1][tag2]") {}
 | 
			
		||||
							
								
								
									
										17
									
								
								tests/ExtraTests/X32-DuplicatedTestCasesDifferentTags.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								tests/ExtraTests/X32-DuplicatedTestCasesDifferentTags.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,17 @@
 | 
			
		||||
 | 
			
		||||
//              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
 | 
			
		||||
 * Checks that test cases with identical name but different tags are
 | 
			
		||||
 * not reported as an error.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <catch2/catch_test_macros.hpp>
 | 
			
		||||
 | 
			
		||||
TEST_CASE("A test case with duplicated name but different tags", "[tag1]") {}
 | 
			
		||||
TEST_CASE("A test case with duplicated name but different tags", "[tag2]") {}
 | 
			
		||||
							
								
								
									
										22
									
								
								tests/ExtraTests/X33-DuplicatedTestCaseMethods.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								tests/ExtraTests/X33-DuplicatedTestCaseMethods.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
			
		||||
 | 
			
		||||
//              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
 | 
			
		||||
 * Checks that test case methods with identical class, name and tags are
 | 
			
		||||
 * reported as error.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <catch2/catch_test_macros.hpp>
 | 
			
		||||
 | 
			
		||||
class TestCaseFixture {
 | 
			
		||||
public:
 | 
			
		||||
    int m_a;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
TEST_CASE_METHOD(TestCaseFixture, "A test case with duplicated name and tags", "[tag1]") {}
 | 
			
		||||
TEST_CASE_METHOD(TestCaseFixture, "A test case with duplicated name and tags", "[tag1]") {}
 | 
			
		||||
@@ -0,0 +1,27 @@
 | 
			
		||||
 | 
			
		||||
//              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
 | 
			
		||||
 * Checks that test case methods with different class, but same name and
 | 
			
		||||
 * tags name and tags are not reported as error.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <catch2/catch_test_macros.hpp>
 | 
			
		||||
 | 
			
		||||
class TestCaseFixture1 {
 | 
			
		||||
public:
 | 
			
		||||
    int m_a;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
class TestCaseFixture2 {
 | 
			
		||||
public:
 | 
			
		||||
    int m_a;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
TEST_CASE_METHOD(TestCaseFixture1, "A test case with duplicated name and tags", "[tag1]") {}
 | 
			
		||||
TEST_CASE_METHOD(TestCaseFixture2, "A test case with duplicated name and tags", "[tag1]") {}
 | 
			
		||||
		Reference in New Issue
	
	Block a user