From 30091d7ba6669fec084db316251b84e4d11410bd Mon Sep 17 00:00:00 2001 From: Geoff Lamrock Date: Thu, 19 Dec 2024 17:02:29 +1100 Subject: [PATCH] Use proper Git repository for stack switch tests (#154) --- .../Stack/StackSwitchCommandHandlerTests.cs | 75 ++++++++++++------- 1 file changed, 46 insertions(+), 29 deletions(-) diff --git a/src/Stack.Tests/Commands/Stack/StackSwitchCommandHandlerTests.cs b/src/Stack.Tests/Commands/Stack/StackSwitchCommandHandlerTests.cs index 60f682d..a790a22 100644 --- a/src/Stack.Tests/Commands/Stack/StackSwitchCommandHandlerTests.cs +++ b/src/Stack.Tests/Commands/Stack/StackSwitchCommandHandlerTests.cs @@ -15,59 +15,70 @@ public class StackSwitchCommandHandlerTests public async Task WhenNoInputsAreProvided_AsksForBranch_ChangesToBranch() { // Arrange - var gitOperations = Substitute.For(); + var sourceBranch = Some.BranchName(); + var anotherBranch = Some.BranchName(); + var branchToSwitchTo = Some.BranchName(); + using var repo = new TestGitRepositoryBuilder() + .WithBranch(sourceBranch) + .WithBranch(branchToSwitchTo) + .Build(); + var stackConfig = Substitute.For(); var inputProvider = Substitute.For(); + var outputProvider = Substitute.For(); + var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings); var handler = new StackSwitchCommandHandler(inputProvider, gitOperations, stackConfig); - var remoteUri = Some.HttpsUri().ToString(); - - gitOperations.GetRemoteUri().Returns(remoteUri); - gitOperations.GetCurrentBranch().Returns("branch-1"); + gitOperations.ChangeBranch(sourceBranch); var stacks = new List( [ - new("Stack1", remoteUri, "branch-1", ["branch-3"]), - new("Stack2", remoteUri, "branch-2", ["branch-4"]) + new("Stack1", repo.RemoteUri, sourceBranch, [branchToSwitchTo]), + new("Stack2", repo.RemoteUri, sourceBranch, [anotherBranch]) ]); stackConfig.Load().Returns(stacks); - inputProvider.SelectGrouped(Questions.SelectBranch, Arg.Any[]>()).Returns("branch-3"); + inputProvider.SelectGrouped(Questions.SelectBranch, Arg.Any[]>()).Returns(branchToSwitchTo); // Act await handler.Handle(new StackSwitchCommandInputs(null)); // Assert - gitOperations.Received().ChangeBranch("branch-3"); + gitOperations.GetCurrentBranch().Should().Be(branchToSwitchTo); } [Fact] public async Task WhenBranchIsProvided_DoesNotAskForBranch_ChangesToBranch() { // Arrange - var gitOperations = Substitute.For(); + var sourceBranch = Some.BranchName(); + var anotherBranch = Some.BranchName(); + var branchToSwitchTo = Some.BranchName(); + using var repo = new TestGitRepositoryBuilder() + .WithBranch(sourceBranch) + .WithBranch(branchToSwitchTo) + .Build(); + var stackConfig = Substitute.For(); var inputProvider = Substitute.For(); + var outputProvider = Substitute.For(); + var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings); var handler = new StackSwitchCommandHandler(inputProvider, gitOperations, stackConfig); - var remoteUri = Some.HttpsUri().ToString(); - - gitOperations.GetRemoteUri().Returns(remoteUri); - gitOperations.GetCurrentBranch().Returns("branch-1"); - gitOperations.DoesLocalBranchExist("branch-3").Returns(true); + gitOperations.ChangeBranch(sourceBranch); var stacks = new List( [ - new("Stack1", remoteUri, "branch-1", ["branch-3"]), - new("Stack2", remoteUri, "branch-2", ["branch-4"]) + new("Stack1", repo.RemoteUri, sourceBranch, [branchToSwitchTo]), + new("Stack2", repo.RemoteUri, sourceBranch, [anotherBranch]) ]); stackConfig.Load().Returns(stacks); // Act - await handler.Handle(new StackSwitchCommandInputs("branch-3")); + await handler.Handle(new StackSwitchCommandInputs(branchToSwitchTo)); // Assert - gitOperations.Received().ChangeBranch("branch-3"); + gitOperations.GetCurrentBranch().Should().Be(branchToSwitchTo); inputProvider.ReceivedCalls().Should().BeEmpty(); } @@ -75,27 +86,33 @@ public async Task WhenBranchIsProvided_DoesNotAskForBranch_ChangesToBranch() public async Task WhenBranchIsProvided_AndBranchDoesNotExist_Throws() { // Arrange - var gitOperations = Substitute.For(); + var sourceBranch = Some.BranchName(); + var anotherBranch = Some.BranchName(); + var branchToSwitchTo = Some.BranchName(); + using var repo = new TestGitRepositoryBuilder() + .WithBranch(sourceBranch) + .WithBranch(branchToSwitchTo) + .Build(); + var stackConfig = Substitute.For(); var inputProvider = Substitute.For(); + var outputProvider = Substitute.For(); + var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings); var handler = new StackSwitchCommandHandler(inputProvider, gitOperations, stackConfig); - var remoteUri = Some.HttpsUri().ToString(); - - gitOperations.GetRemoteUri().Returns(remoteUri); - gitOperations.GetCurrentBranch().Returns("branch-1"); - gitOperations.DoesLocalBranchExist("branch-3").Returns(false); + gitOperations.ChangeBranch(sourceBranch); var stacks = new List( [ - new("Stack1", remoteUri, "branch-1", ["branch-3"]), - new("Stack2", remoteUri, "branch-2", ["branch-4"]) + new("Stack1", repo.RemoteUri, sourceBranch, [branchToSwitchTo]), + new("Stack2", repo.RemoteUri, sourceBranch, [anotherBranch]) ]); stackConfig.Load().Returns(stacks); // Act and assert - await handler.Invoking(h => h.Handle(new StackSwitchCommandInputs("branch-3"))) + var invalidBranchName = Some.BranchName(); + await handler.Invoking(h => h.Handle(new StackSwitchCommandInputs(invalidBranchName))) .Should().ThrowAsync() - .WithMessage("Branch 'branch-3' does not exist."); + .WithMessage($"Branch '{invalidBranchName}' does not exist."); } }