Skip to content

test that CliConfiguration can be intentionally subclassed #2148

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 33 additions & 0 deletions src/System.CommandLine.Tests/CommandLineConfigurationTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -260,4 +260,37 @@ public void ThrowIfInvalid_throws_if_a_parentage_cycle_is_detected()
.Should()
.Be($"Cycle detected in command tree. Command '{rootCommand.Name}' is its own ancestor.");
}

[Fact]
public void It_can_be_subclassed_to_provide_additional_context()
{
var command = new CliRootCommand();
var commandWasInvoked = false;
command.SetAction(parseResult =>
{
var appConfig = (CustomAppConfiguration)parseResult.Configuration;

// access custom config

commandWasInvoked = true;

return 0;
});

var config = new CustomAppConfiguration(command);

config.Invoke("");

commandWasInvoked.Should().BeTrue();
}
}

public class CustomAppConfiguration : CliConfiguration
{
public CustomAppConfiguration(CliRootCommand command) : base(command)
{
EnableDefaultExceptionHandler = false;
}

public IServiceProvider ServiceProvider { get; }
}