mirror of
https://github.com/Tyrrrz/CliFx.git
synced 2025-10-25 15:19:17 +00:00
Show choices on non-scalar enum parameters and options (#102)
This commit is contained in:
@@ -577,6 +577,51 @@ public class Command : ICommand
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public async Task Help_text_shows_all_valid_values_for_non_scalar_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 List<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]
|
[Fact]
|
||||||
public async Task Help_text_shows_environment_variables_for_options_that_have_them_configured_as_fallback()
|
public async Task Help_text_shows_environment_variables_for_options_that_have_them_configured_as_fallback()
|
||||||
{
|
{
|
||||||
@@ -875,4 +920,4 @@ public class SecondCommandSecondChildCommand : ICommand
|
|||||||
stdOut.Trim().Should().Be("v6.9");
|
stdOut.Trim().Should().Be("v6.9");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,17 @@ namespace CliFx.Schema
|
|||||||
|
|
||||||
public IReadOnlyList<object?> GetValidValues()
|
public IReadOnlyList<object?> GetValidValues()
|
||||||
{
|
{
|
||||||
var underlyingType = Type.TryGetNullableUnderlyingType() ?? Type;
|
Type typeToCheck = Type;
|
||||||
|
foreach (var inf in typeToCheck.GetInterfaces())
|
||||||
|
{
|
||||||
|
if (inf.IsGenericType && inf.GetGenericTypeDefinition() == typeof(IEnumerable<>))
|
||||||
|
{
|
||||||
|
typeToCheck = inf.GenericTypeArguments[0];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var underlyingType = typeToCheck.TryGetNullableUnderlyingType() ?? typeToCheck;
|
||||||
|
|
||||||
// We can only get valid values for enums
|
// We can only get valid values for enums
|
||||||
if (underlyingType.IsEnum)
|
if (underlyingType.IsEnum)
|
||||||
@@ -30,4 +40,4 @@ namespace CliFx.Schema
|
|||||||
return Array.Empty<object?>();
|
return Array.Empty<object?>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user