mirror of
				https://github.com/Tyrrrz/CliFx.git
				synced 2025-10-25 15:19:17 +00:00 
			
		
		
		
	Show choices for nullable enums in enumerable (#105)
This commit is contained in:
		| @@ -622,6 +622,51 @@ public class Command : ICommand | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public async Task Help_text_shows_all_valid_values_for_nullable_enum_parameters_and_options() | ||||
|         { | ||||
|             // Arrange | ||||
|             var commandType = DynamicCommandBuilder.Compile( | ||||
|                 // language=cs | ||||
|                 @" | ||||
| public enum CustomEnum { One, Two, Three } | ||||
|  | ||||
| [Command] | ||||
| public class Command : ICommand | ||||
| { | ||||
|     [CommandParameter(0)] | ||||
|     public CustomEnum? Foo { get; set; } | ||||
|  | ||||
|     [CommandOption(""bar"")] | ||||
|     public List<CustomEnum?> Bar { get; set; } | ||||
|  | ||||
|     public ValueTask ExecuteAsync(IConsole console) => default; | ||||
| } | ||||
| "); | ||||
|  | ||||
|             var application = new CliApplicationBuilder() | ||||
|                 .AddCommand(commandType) | ||||
|                 .UseConsole(FakeConsole) | ||||
|                 .Build(); | ||||
|  | ||||
|             // Act | ||||
|             var exitCode = await application.RunAsync( | ||||
|                 new[] {"--help"}, | ||||
|                 new Dictionary<string, string>() | ||||
|             ); | ||||
|  | ||||
|             var stdOut = FakeConsole.ReadOutputString(); | ||||
|  | ||||
|             // Assert | ||||
|             exitCode.Should().Be(0); | ||||
|             stdOut.Should().ContainAllInOrder( | ||||
|                 "PARAMETERS", | ||||
|                 "foo", "Choices:", "One", "Two", "Three", | ||||
|                 "OPTIONS", | ||||
|                 "--bar", "Choices:", "One", "Two", "Three" | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         [Fact] | ||||
|         public async Task Help_text_shows_environment_variables_for_options_that_have_them_configured_as_fallback() | ||||
|         { | ||||
|   | ||||
| @@ -21,10 +21,8 @@ namespace CliFx.Schema | ||||
|  | ||||
|         public IReadOnlyList<object?> GetValidValues() | ||||
|         { | ||||
|             var underlyingType = | ||||
|                 Type.TryGetNullableUnderlyingType() ?? | ||||
|                 Type.TryGetEnumerableUnderlyingType() ?? | ||||
|                 Type; | ||||
|             var underlyingType = Type.TryGetEnumerableUnderlyingType() ?? Type; | ||||
|             underlyingType = underlyingType.TryGetNullableUnderlyingType() ?? underlyingType; | ||||
|  | ||||
|             // We can only get valid values for enums | ||||
|             if (underlyingType.IsEnum) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user