Skip to content
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

Use proper Git repository for new stack tests #148

Merged
merged 32 commits into from
Dec 19, 2024
Merged
Changes from 1 commit
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
81d5c5a
Wip adding proper Git tests
geofflamrock Dec 15, 2024
5789694
Use output provider for Git operations
geofflamrock Dec 16, 2024
19c5dbe
Use output provider in GitHub operations
geofflamrock Dec 16, 2024
15f16a0
Merge branch 'git-operations-use-output-provider' into proper-git-tes…
geofflamrock Dec 16, 2024
d591429
More wip
geofflamrock Dec 16, 2024
ab16a65
Merge branch 'main' into proper-git-tests-1
geofflamrock Dec 16, 2024
d92f997
More add branch tests with proper Git repo
geofflamrock Dec 16, 2024
3eddc88
Change single new branch test to use proper Git repo
geofflamrock Dec 16, 2024
f2956a0
Cleanup
geofflamrock Dec 16, 2024
1c9274a
Merge branch 'proper-git-tests-1' into proper-git-tests-2
geofflamrock Dec 16, 2024
6530c28
More new branch tests with Git repo
geofflamrock Dec 16, 2024
d05eceb
Add initial cleanup stack test with proper Git repo
geofflamrock Dec 16, 2024
149e319
Some cleanup
geofflamrock Dec 16, 2024
eff579b
Make all cleanup tests use proper Git repo
geofflamrock Dec 17, 2024
3459f44
Change delete stack test that cleans up branches to use proper Git repo
geofflamrock Dec 17, 2024
460892d
Make all delete tests use proper Git repo
geofflamrock Dec 17, 2024
35ce798
Cleanup
geofflamrock Dec 17, 2024
6c4c6c8
Change new stack tests to use proper Git repo
geofflamrock Dec 17, 2024
fd76b3b
Merge branch 'main' into proper-git-tests-2
geofflamrock Dec 17, 2024
fe228f8
Merge branch 'proper-git-tests-2' into proper-git-tests-3
geofflamrock Dec 17, 2024
f58a17a
Merge branch 'proper-git-tests-3' into proper-git-tests-4
geofflamrock Dec 17, 2024
b7b63da
Merge branch 'proper-git-tests-4' into proper-git-tests-5
geofflamrock Dec 17, 2024
38c48e8
Fix namespace
geofflamrock Dec 17, 2024
712c568
Merge branch 'proper-git-tests-2' into proper-git-tests-3
geofflamrock Dec 17, 2024
238d186
Merge branch 'proper-git-tests-3' into proper-git-tests-4
geofflamrock Dec 17, 2024
f349195
Merge branch 'proper-git-tests-4' into proper-git-tests-5
geofflamrock Dec 17, 2024
bc2df72
Merge branch 'main' into proper-git-tests-3
geofflamrock Dec 17, 2024
8a302de
Merge branch 'proper-git-tests-3' into proper-git-tests-4
geofflamrock Dec 17, 2024
e51d3ac
Merge branch 'proper-git-tests-4' into proper-git-tests-5
geofflamrock Dec 17, 2024
c3afcc8
Merge branch 'main' into proper-git-tests-4
geofflamrock Dec 19, 2024
6f45191
Merge branch 'proper-git-tests-4' into proper-git-tests-5
geofflamrock Dec 19, 2024
6313448
Merge branch 'main' into proper-git-tests-5
geofflamrock Dec 19, 2024
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
Prev Previous commit
Next Next commit
Change single new branch test to use proper Git repo
geofflamrock committed Dec 16, 2024
commit 3eddc88999e6c144132d42fcf63a960bf75d53e9
28 changes: 15 additions & 13 deletions src/Stack.Tests/Commands/Branch/NewBranchCommandHandlerTests.cs
Original file line number Diff line number Diff line change
@@ -15,30 +15,32 @@ public class NewBranchCommandHandlerTests
public async Task WhenNoInputsProvided_AsksForStackAndBranchAndConfirms_CreatesAndAddsBranchToStackAndSwitchesToBranch()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var anotherBranch = Some.BranchName();
var newBranch = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch)
.WithBranch(anotherBranch)
.Build();

var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new NewBranchCommandHandler(inputProvider, outputProvider, gitOperations, stackConfig);

var remoteUri = Some.HttpsUri().ToString();

gitOperations.GetRemoteUri().Returns(remoteUri);
gitOperations.GetCurrentBranch().Returns("branch-1");
gitOperations.DoesLocalBranchExist("branch-5").Returns(false);

var stacks = new List<Config.Stack>(
[
new("Stack1", remoteUri, "branch-1", ["branch-3"]),
new("Stack2", remoteUri, "branch-2", ["branch-4"])
new("Stack1", repo.RemoteUri, sourceBranch, [anotherBranch]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
]);
stackConfig.Load().Returns(stacks);
stackConfig
.WhenForAnyArgs(s => s.Save(Arg.Any<List<Config.Stack>>()))
.Do(ci => stacks = ci.ArgAt<List<Config.Stack>>(0));

inputProvider.Select(Questions.SelectStack, Arg.Any<string[]>()).Returns("Stack1");
inputProvider.Text(Questions.BranchName, Arg.Any<string>()).Returns("branch-5");
inputProvider.Text(Questions.BranchName, Arg.Any<string>()).Returns(newBranch);
inputProvider.Confirm(Questions.ConfirmSwitchToBranch).Returns(true);

// Act
@@ -47,10 +49,10 @@ public async Task WhenNoInputsProvided_AsksForStackAndBranchAndConfirms_CreatesA
// Assert
stacks.Should().BeEquivalentTo(new List<Config.Stack>
{
new("Stack1", remoteUri, "branch-1", ["branch-3", "branch-5"]),
new("Stack2", remoteUri, "branch-2", ["branch-4"])
new("Stack1", repo.RemoteUri, sourceBranch, [anotherBranch, newBranch]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
});
gitOperations.Received().ChangeBranch("branch-5");
gitOperations.GetCurrentBranch().Should().Be(newBranch);
}

[Fact]
1 change: 0 additions & 1 deletion src/Stack/Commands/Branch/NewBranchCommand.cs
Original file line number Diff line number Diff line change
@@ -61,7 +61,6 @@ public async Task<NewBranchCommandResponse> Handle(NewBranchCommandInputs inputs
{
await Task.CompletedTask;

var defaultBranch = gitOperations.GetDefaultBranch();
var remoteUri = gitOperations.GetRemoteUri();
var currentBranch = gitOperations.GetCurrentBranch();
var branches = gitOperations.GetLocalBranchesOrderedByMostRecentCommitterDate();