mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-31 12:17:11 +01:00 
			
		
		
		
	Moved enum tests that depend on internals to IntrospectiveTests.
- also factored out makeEnumInfo, so tests don't need to touch registry - and added usage test that involves namespace
This commit is contained in:
		| @@ -22,6 +22,7 @@ set(TEST_SOURCES | ||||
|         ${SELF_TEST_DIR}/IntrospectiveTests/Tag.tests.cpp | ||||
|         ${SELF_TEST_DIR}/IntrospectiveTests/String.tests.cpp | ||||
|         ${SELF_TEST_DIR}/IntrospectiveTests/Xml.tests.cpp | ||||
|         ${SELF_TEST_DIR}/IntrospectiveTests/ToString.tests.cpp | ||||
|         ${SELF_TEST_DIR}/UsageTests/Approx.tests.cpp | ||||
|         ${SELF_TEST_DIR}/UsageTests/BDD.tests.cpp | ||||
|         ${SELF_TEST_DIR}/UsageTests/Benchmark.tests.cpp | ||||
|   | ||||
							
								
								
									
										42
									
								
								projects/SelfTest/IntrospectiveTests/ToString.tests.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								projects/SelfTest/IntrospectiveTests/ToString.tests.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| #include "catch.hpp" | ||||
|  | ||||
| #include "internal/catch_enum_values_registry.h" | ||||
|  | ||||
| enum class EnumClass3 { Value1, Value2, Value3, Value4 }; | ||||
|  | ||||
|  | ||||
| TEST_CASE( "parseEnums", "[Strings][enums]" ) { | ||||
|     using namespace Catch::Matchers; | ||||
|     using Catch::Detail::parseEnums; | ||||
|  | ||||
|     SECTION( "No enums" ) | ||||
|         CHECK_THAT( parseEnums( "" ), Equals( std::vector<std::string>{} ) ); | ||||
|  | ||||
|     SECTION( "One enum value" ) { | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1" ), | ||||
|                 Equals(std::vector<std::string>{"Value1"} ) ); | ||||
|         CHECK_THAT( parseEnums( "Value1" ), | ||||
|                 Equals( std::vector<std::string>{"Value1"} ) ); | ||||
|         CHECK_THAT( parseEnums( "EnumName::Value1" ), | ||||
|                 Equals(std::vector<std::string>{"Value1"} ) ); | ||||
|     } | ||||
|  | ||||
|     SECTION( "Multiple enum values" ) { | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2"} ) ); | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2, ClassName::EnumName::Value3" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2", "Value3"} ) ); | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1,ClassName::EnumName::Value2 , ClassName::EnumName::Value3" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2", "Value3"} ) ); | ||||
|     } | ||||
| } | ||||
|  | ||||
| TEST_CASE( "Directly creating an EnumInfo" ) { | ||||
|  | ||||
|     using namespace Catch::Detail; | ||||
|     std::unique_ptr<EnumInfo> enumInfo = makeEnumInfo( "EnumName", "EnumName::Value1, EnumName::Value2", {0, 1} ); | ||||
|  | ||||
|     CHECK( enumInfo->lookup(0) == "Value1" ); | ||||
|     CHECK( enumInfo->lookup(1) == "Value2" ); | ||||
|     CHECK( enumInfo->lookup(3) == "{** unexpected enum value **}" ); | ||||
| } | ||||
| @@ -61,7 +61,7 @@ TEST_CASE( "toString(enum class w/operator<<)", "[toString][enum][enumClass]" ) | ||||
|     EnumClass2 e1 = EnumClass2::EnumClass2Value1; | ||||
|     CHECK( ::Catch::Detail::stringify(e1) == "E2/V1" ); | ||||
|  | ||||
|     EnumClass2 e3 = static_cast<EnumClass2>(10); | ||||
|     auto e3 = static_cast<EnumClass2>(10); | ||||
|     CHECK( ::Catch::Detail::stringify(e3) == "Unknown enum value 10" ); | ||||
| } | ||||
|  | ||||
| @@ -70,7 +70,7 @@ enum class EnumClass3 { Value1, Value2, Value3, Value4 }; | ||||
| CATCH_REGISTER_ENUM( EnumClass3, EnumClass3::Value1, EnumClass3::Value2, EnumClass3::Value3 ) | ||||
|  | ||||
|  | ||||
| TEST_CASE( "REGISTER_ENUM" ) { | ||||
| TEST_CASE( "Enums can quickly have stringification enabled using REGISTER_ENUM" ) { | ||||
|     using Catch::Detail::stringify; | ||||
|     REQUIRE( stringify( EnumClass3::Value1 ) == "Value1" ); | ||||
|     REQUIRE( stringify( EnumClass3::Value2 ) == "Value2" ); | ||||
| @@ -81,40 +81,19 @@ TEST_CASE( "REGISTER_ENUM" ) { | ||||
|     REQUIRE( stringify( ec3 ) == "Value2" ); | ||||
| } | ||||
|  | ||||
| #include "internal/catch_interfaces_enum_values_registry.h" | ||||
|  | ||||
| TEST_CASE( "EnumInfo" ) { | ||||
|  | ||||
|     auto& hub = Catch::getMutableRegistryHub(); | ||||
|     auto& reg = hub.getMutableEnumValuesRegistry(); | ||||
|     auto const& enumInfo = reg.registerEnum( "EnumName", "EnumName::Value1, EnumName::Value2", {0, 1} ); | ||||
|  | ||||
|     CHECK( enumInfo.lookup(0) == "Value1" ); | ||||
|     CHECK( enumInfo.lookup(1) == "Value2" ); | ||||
|     CHECK( enumInfo.lookup(3) == "{** unexpected enum value **}" ); | ||||
| namespace Bikeshed { | ||||
|     enum class Colours { Red, Green, Blue }; | ||||
| } | ||||
|  | ||||
| #include "internal/catch_enum_values_registry.h" | ||||
| // Important!: This macro must appear at top level scope - not inside a namespace | ||||
| // You can fully qualify the names, or use a using if you prefer | ||||
| CATCH_REGISTER_ENUM( Bikeshed::Colours, | ||||
|                      Bikeshed::Colours::Red, | ||||
|                      Bikeshed::Colours::Green, | ||||
|                      Bikeshed::Colours::Blue ); | ||||
|  | ||||
| TEST_CASE( "parseEnums", "[Strings][enums]" ) { | ||||
|     using namespace Catch::Matchers; | ||||
|     using Catch::Detail::parseEnums; | ||||
|  | ||||
|     SECTION( "No enums" ) | ||||
|         CHECK_THAT( parseEnums( "" ), Equals( std::vector<std::string>{} ) ); | ||||
|  | ||||
|     SECTION( "One enum value" ) { | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1" ), Equals(std::vector<std::string>{"Value1"} ) ); | ||||
|         CHECK_THAT( parseEnums( "Value1" ), Equals( std::vector<std::string>{"Value1"} ) ); | ||||
|         CHECK_THAT( parseEnums( "EnumName::Value1" ), Equals(std::vector<std::string>{"Value1"} ) ); | ||||
|     } | ||||
|  | ||||
|     SECTION( "Multiple enum values" ) { | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2"} ) ); | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1, ClassName::EnumName::Value2, ClassName::EnumName::Value3" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2", "Value3"} ) ); | ||||
|         CHECK_THAT( parseEnums( "ClassName::EnumName::Value1,ClassName::EnumName::Value2 , ClassName::EnumName::Value3" ), | ||||
|                     Equals( std::vector<std::string>{"Value1", "Value2", "Value3"} ) ); | ||||
|     } | ||||
| TEST_CASE( "Enums in namespaces can quickly have stringification enabled using REGISTER_ENUM" ) { | ||||
|     using Catch::Detail::stringify; | ||||
|     REQUIRE( stringify( Bikeshed::Colours::Red ) == "Red" ); | ||||
|     REQUIRE( stringify( Bikeshed::Colours::Blue ) == "Blue" ); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Phil nash
					Phil nash