mirror of
https://github.com/nsnail/spectre.console.git
synced 2025-04-16 00:42:51 +08:00

Shows help if the default command was called without any arguments but has required arguments. This way it does not hinder execution of a default command without any required arguments. When called without args: - Default command with required params -> Show help - Default command with required params and additional commands -> Show help including additional commands - Default command without required params -> Execute command
377 lines
12 KiB
C#
377 lines
12 KiB
C#
using Spectre.Console.Cli;
|
|
|
|
namespace Spectre.Console.Tests.Unit.Cli;
|
|
|
|
public sealed partial class CommandAppTests
|
|
{
|
|
[UsesVerify]
|
|
[ExpectationPath("Help")]
|
|
public class Help
|
|
{
|
|
[Fact]
|
|
[Expectation("Root")]
|
|
public Task Should_Output_Root_Correctly()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<DogCommand>("dog");
|
|
configurator.AddCommand<HorseCommand>("horse");
|
|
configurator.AddCommand<GiraffeCommand>("giraffe");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Hidden_Commands")]
|
|
public Task Should_Skip_Hidden_Commands()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<DogCommand>("dog");
|
|
configurator.AddCommand<HorseCommand>("horse");
|
|
configurator.AddCommand<GiraffeCommand>("giraffe")
|
|
.WithExample(new[] { "giraffe", "123" })
|
|
.IsHidden();
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Description_No_Trailing_Period")]
|
|
public Task Should_Not_Trim_Description_Trailing_Period()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<DogCommand>("dog");
|
|
configurator.AddCommand<HorseCommand>("horse");
|
|
configurator.AddCommand<GiraffeCommand>("giraffe")
|
|
.WithExample(new[] { "giraffe", "123" })
|
|
.IsHidden();
|
|
configurator.TrimTrailingPeriods(false);
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Command")]
|
|
public Task Should_Output_Command_Correctly()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddBranch<CatSettings>("cat", animal =>
|
|
{
|
|
animal.SetDescription("Contains settings for a cat.");
|
|
animal.AddCommand<LionCommand>("lion");
|
|
});
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("cat", "--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Leaf")]
|
|
public Task Should_Output_Leaf_Correctly()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddBranch<CatSettings>("cat", animal =>
|
|
{
|
|
animal.SetDescription("Contains settings for a cat.");
|
|
animal.AddCommand<LionCommand>("lion");
|
|
});
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("cat", "lion", "--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Default")]
|
|
public Task Should_Output_Default_Command_Correctly()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<LionCommand>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Default_Without_Args")]
|
|
public Task Should_Output_Default_Command_When_Command_Has_Required_Parameters_And_Is_Called_Without_Args()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<LionCommand>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run();
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Default_Without_Args_Additional")]
|
|
public Task Should_Output_Default_Command_And_Additional_Commands_When_Default_Command_Has_Required_Parameters_And_Is_Called_Without_Args()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<LionCommand>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<GiraffeCommand>("giraffe");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run();
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Greeter_Default")]
|
|
public Task Should_Not_Output_Default_Command_When_Command_Has_No_Required_Parameters_And_Is_Called_Without_Args()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<GreeterCommand>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run();
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("RootExamples")]
|
|
public Task Should_Output_Root_Examples_Defined_On_Root()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddExample(new[] { "dog", "--name", "Rufus", "--age", "12", "--good-boy" });
|
|
configurator.AddExample(new[] { "horse", "--name", "Brutus" });
|
|
configurator.AddCommand<DogCommand>("dog");
|
|
configurator.AddCommand<HorseCommand>("horse");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("RootExamples_Children")]
|
|
public Task Should_Output_Root_Examples_Defined_On_Direct_Children_If_Root_Have_No_Examples()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<DogCommand>("dog")
|
|
.WithExample(new[] { "dog", "--name", "Rufus", "--age", "12", "--good-boy" });
|
|
configurator.AddCommand<HorseCommand>("horse")
|
|
.WithExample(new[] { "horse", "--name", "Brutus" });
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("RootExamples_Leafs")]
|
|
public Task Should_Output_Root_Examples_Defined_On_Leaves_If_No_Other_Examples_Are_Found()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddBranch<AnimalSettings>("animal", animal =>
|
|
{
|
|
animal.SetDescription("The animal command.");
|
|
animal.AddCommand<DogCommand>("dog")
|
|
.WithExample(new[] { "animal", "dog", "--name", "Rufus", "--age", "12", "--good-boy" });
|
|
animal.AddCommand<HorseCommand>("horse")
|
|
.WithExample(new[] { "animal", "horse", "--name", "Brutus" });
|
|
});
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("CommandExamples")]
|
|
public Task Should_Only_Output_Command_Examples_Defined_On_Command()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddBranch<AnimalSettings>("animal", animal =>
|
|
{
|
|
animal.SetDescription("The animal command.");
|
|
animal.AddExample(new[] { "animal", "--help" });
|
|
|
|
animal.AddCommand<DogCommand>("dog")
|
|
.WithExample(new[] { "animal", "dog", "--name", "Rufus", "--age", "12", "--good-boy" });
|
|
animal.AddCommand<HorseCommand>("horse")
|
|
.WithExample(new[] { "animal", "horse", "--name", "Brutus" });
|
|
});
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("animal", "--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("DefaultExamples")]
|
|
public Task Should_Output_Root_Examples_If_Default_Command_Is_Specified()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<LionCommand>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddExample(new[] { "12", "-c", "3" });
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("NoDescription")]
|
|
public Task Should_Not_Show_Truncated_Command_Table_If_Commands_Are_Missing_Description()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
configurator.AddCommand<NoDescriptionCommand>("bar");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("ArgumentOrder")]
|
|
public Task Should_List_Arguments_In_Correct_Order()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<GenericCommand<ArgumentOrderSettings>>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
|
|
[Fact]
|
|
[Expectation("Hidden_Command_Options")]
|
|
public Task Should_Not_Show_Hidden_Command_Options()
|
|
{
|
|
// Given
|
|
var fixture = new CommandAppTester();
|
|
fixture.SetDefaultCommand<GenericCommand<HiddenOptionSettings>>();
|
|
fixture.Configure(configurator =>
|
|
{
|
|
configurator.SetApplicationName("myapp");
|
|
});
|
|
|
|
// When
|
|
var result = fixture.Run("--help");
|
|
|
|
// Then
|
|
return Verifier.Verify(result.Output);
|
|
}
|
|
}
|
|
} |