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 open pull requests tests #158

Merged
merged 81 commits into from
Dec 19, 2024
Merged
Changes from all commits
Commits
Show all changes
81 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
78cd1dc
Use proper Git repository for remove branch tests
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
1b8493a
Merge branch 'proper-git-tests-5' into proper-git-tests-remove-branch
geofflamrock Dec 17, 2024
8e335c0
Use proper Git repository for stack switch tests
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
a6733a4
Merge branch 'proper-git-tests-5' into proper-git-tests-remove-branch
geofflamrock Dec 17, 2024
5e1308c
Merge branch 'proper-git-tests-remove-branch' into proper-git-tests-s…
geofflamrock Dec 17, 2024
e44bdf0
Improvements to git repo building
geofflamrock Dec 18, 2024
6f61ec3
Use proper Git repository for stack update tests
geofflamrock Dec 19, 2024
375d245
Use proper Git repository for create pr tests
geofflamrock Dec 19, 2024
16a496e
Fix variable names
geofflamrock Dec 19, 2024
064bf42
Use proper Git repository for pr open tests
geofflamrock Dec 19, 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
fe5cf5f
Merge branch 'proper-git-tests-5' into proper-git-tests-remove-branch
geofflamrock Dec 19, 2024
12d2211
Merge branch 'proper-git-tests-remove-branch' into proper-git-tests-s…
geofflamrock Dec 19, 2024
9c9ae36
Merge branch 'proper-git-tests-stack-switch' into proper-git-tests-st…
geofflamrock Dec 19, 2024
db16704
Merge branch 'proper-git-tests-stack-status' into proper-git-tests-up…
geofflamrock Dec 19, 2024
2160b96
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
dbd25d3
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
6313448
Merge branch 'main' into proper-git-tests-5
geofflamrock Dec 19, 2024
73db4aa
Merge branch 'proper-git-tests-5' into proper-git-tests-remove-branch
geofflamrock Dec 19, 2024
622c692
Merge branch 'proper-git-tests-remove-branch' into proper-git-tests-s…
geofflamrock Dec 19, 2024
6acf141
Merge branch 'proper-git-tests-stack-switch' into proper-git-tests-st…
geofflamrock Dec 19, 2024
c4d80d8
Merge branch 'proper-git-tests-stack-status' into proper-git-tests-up…
geofflamrock Dec 19, 2024
e437f05
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
5e18ff1
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
4af8f68
Merge branch 'main' into proper-git-tests-remove-branch
geofflamrock Dec 19, 2024
b0b424b
Merge branch 'proper-git-tests-remove-branch' into proper-git-tests-s…
geofflamrock Dec 19, 2024
fdf1872
Merge branch 'proper-git-tests-stack-switch' into proper-git-tests-st…
geofflamrock Dec 19, 2024
1451f87
Merge branch 'proper-git-tests-stack-status' into proper-git-tests-up…
geofflamrock Dec 19, 2024
416a69b
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
324af7f
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
97b2b9c
Merge branch 'main' into proper-git-tests-stack-switch
geofflamrock Dec 19, 2024
b2f888a
Merge branch 'proper-git-tests-stack-switch' into proper-git-tests-st…
geofflamrock Dec 19, 2024
159536a
Merge branch 'proper-git-tests-stack-status' into proper-git-tests-up…
geofflamrock Dec 19, 2024
810f294
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
fb055df
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
529f9a4
Merge branch 'main' into proper-git-tests-stack-status
geofflamrock Dec 19, 2024
af05e4f
Merge branch 'proper-git-tests-stack-status' into proper-git-tests-up…
geofflamrock Dec 19, 2024
d218753
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
3d0c084
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
ac13d72
Merge branch 'main' into proper-git-tests-update-stack
geofflamrock Dec 19, 2024
c8c7d3e
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
f47e3e5
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
02e2fbb
Use test output provider for debugging
geofflamrock Dec 19, 2024
f8340f1
Set committer details to get test to run
geofflamrock Dec 19, 2024
eb98f90
Set user.name and user.email in tests
geofflamrock Dec 19, 2024
780da87
Move TestOutputProvider to separate file
geofflamrock Dec 19, 2024
b2d8059
Merge branch 'proper-git-tests-update-stack' into proper-git-tests-cr…
geofflamrock Dec 19, 2024
ebe02c0
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
fe6d182
Merge branch 'main' into proper-git-tests-create-pr
geofflamrock Dec 19, 2024
db3f7bc
Merge branch 'proper-git-tests-create-pr' into proper-git-tests-pr-open
geofflamrock Dec 19, 2024
e81b699
Merge branch 'main' into proper-git-tests-pr-open
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
Original file line number Diff line number Diff line change
Expand Up @@ -7,30 +7,35 @@
using Stack.Infrastructure;
using Stack.Tests.Helpers;

namespace Stack.Tests.Commands.Stack;
namespace Stack.Tests.Commands.PullRequests;

public class OpenPullRequestsCommandHandlerTests
{
[Fact]
public async Task WhenThereAreMultiplePullRequestsInAStack_OpensAllPullRequests()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var branch1 = Some.BranchName();
var branch2 = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch, true)
.WithBranch(branch1, true)
.WithBranch(branch2, true)
.Build();

var gitHubOperations = Substitute.For<IGitHubOperations>();
var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var fileOperations = Substitute.For<IFileOperations>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new OpenPullRequestsCommandHandler(inputProvider, outputProvider, gitOperations, gitHubOperations, stackConfig);

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

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

var stacks = 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, [branch1, branch2]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
]);
stackConfig.Load().Returns(stacks);
stackConfig
Expand All @@ -39,44 +44,49 @@ public async Task WhenThereAreMultiplePullRequestsInAStack_OpensAllPullRequests(

inputProvider.Select(Questions.SelectStack, Arg.Any<string[]>()).Returns("Stack1");

var prForBranch3 = new GitHubPullRequest(1, "PR Title for branch-3", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch1 = new GitHubPullRequest(1, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-3")
.Returns(prForBranch3);
.GetPullRequest(branch1)
.Returns(prForBranch1);

var prForBranch5 = new GitHubPullRequest(2, "PR Title for branch-5", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch2 = new GitHubPullRequest(2, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-5")
.Returns(prForBranch5);
.GetPullRequest(branch2)
.Returns(prForBranch2);

// Act
await handler.Handle(OpenPullRequestsCommandInputs.Empty);

// Assert
gitHubOperations.Received().OpenPullRequest(prForBranch3);
gitHubOperations.Received().OpenPullRequest(prForBranch5);
gitHubOperations.Received().OpenPullRequest(prForBranch1);
gitHubOperations.Received().OpenPullRequest(prForBranch2);
}

[Fact]
public async Task WhenThereAreSomePullRequestsInAStack_OpensAllPullRequests()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var branch1 = Some.BranchName();
var branch2 = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch, true)
.WithBranch(branch1, true)
.WithBranch(branch2, true)
.Build();

var gitHubOperations = Substitute.For<IGitHubOperations>();
var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var fileOperations = Substitute.For<IFileOperations>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new OpenPullRequestsCommandHandler(inputProvider, outputProvider, gitOperations, gitHubOperations, stackConfig);

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

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

var stacks = 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, [branch1, branch2]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
]);
stackConfig.Load().Returns(stacks);
stackConfig
Expand All @@ -85,135 +95,140 @@ public async Task WhenThereAreSomePullRequestsInAStack_OpensAllPullRequests()

inputProvider.Select(Questions.SelectStack, Arg.Any<string[]>()).Returns("Stack1");

var prForBranch3 = new GitHubPullRequest(1, "PR Title for branch-3", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch1 = new GitHubPullRequest(1, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-3")
.Returns(prForBranch3);
.GetPullRequest(branch1)
.Returns(prForBranch1);

var prForBranch5 = new GitHubPullRequest(2, "PR Title for branch-5", string.Empty, GitHubPullRequestStates.Closed, Some.HttpsUri(), false);
var prForBranch2 = new GitHubPullRequest(2, "PR Title", string.Empty, GitHubPullRequestStates.Closed, Some.HttpsUri(), false);

// Act
await handler.Handle(OpenPullRequestsCommandInputs.Empty);

// Assert
gitHubOperations.Received().OpenPullRequest(prForBranch3);
gitHubOperations.DidNotReceive().OpenPullRequest(prForBranch5);
gitHubOperations.Received().OpenPullRequest(prForBranch1);
gitHubOperations.DidNotReceive().OpenPullRequest(prForBranch2);
}

[Fact]
public async Task WhenStackNameIsProvided_OpensAllPullRequestsForTheStack()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var branch1 = Some.BranchName();
var branch2 = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch, true)
.WithBranch(branch1, true)
.WithBranch(branch2, true)
.Build();

var gitHubOperations = Substitute.For<IGitHubOperations>();
var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var fileOperations = Substitute.For<IFileOperations>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new OpenPullRequestsCommandHandler(inputProvider, outputProvider, gitOperations, gitHubOperations, stackConfig);

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

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

var stacks = 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, [branch1, branch2]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
]);
stackConfig.Load().Returns(stacks);

var prForBranch3 = new GitHubPullRequest(1, "PR Title for branch-3", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch1 = new GitHubPullRequest(1, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-3")
.Returns(prForBranch3);
.GetPullRequest(branch1)
.Returns(prForBranch1);

var prForBranch5 = new GitHubPullRequest(2, "PR Title for branch-5", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch2 = new GitHubPullRequest(2, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-5")
.Returns(prForBranch5);
.GetPullRequest(branch2)
.Returns(prForBranch2);

// Act
await handler.Handle(new OpenPullRequestsCommandInputs("Stack1"));

// Assert
gitHubOperations.Received().OpenPullRequest(prForBranch3);
gitHubOperations.Received().OpenPullRequest(prForBranch5);
gitHubOperations.Received().OpenPullRequest(prForBranch1);
gitHubOperations.Received().OpenPullRequest(prForBranch2);
}

[Fact]
public async Task WhenOnlyOneStackExists_DoesNotAskForStackName_OpensAllPullRequestsForTheStack()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var branch1 = Some.BranchName();
var branch2 = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch, true)
.WithBranch(branch1, true)
.WithBranch(branch2, true)
.Build();

var gitHubOperations = Substitute.For<IGitHubOperations>();
var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var fileOperations = Substitute.For<IFileOperations>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new OpenPullRequestsCommandHandler(inputProvider, outputProvider, gitOperations, gitHubOperations, stackConfig);

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

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

var stacks = new List<Config.Stack>(
[
new("Stack1", remoteUri, "branch-1", ["branch-3", "branch-5"])
new("Stack1", repo.RemoteUri, sourceBranch, [branch1, branch2])
]);
stackConfig.Load().Returns(stacks);

var prForBranch3 = new GitHubPullRequest(1, "PR Title for branch-3", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch1 = new GitHubPullRequest(1, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-3")
.Returns(prForBranch3);
.GetPullRequest(branch1)
.Returns(prForBranch1);

var prForBranch5 = new GitHubPullRequest(2, "PR Title for branch-5", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
var prForBranch2 = new GitHubPullRequest(2, "PR Title", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-5")
.Returns(prForBranch5);
.GetPullRequest(branch2)
.Returns(prForBranch2);

// Act
await handler.Handle(OpenPullRequestsCommandInputs.Empty);

// Assert
gitHubOperations.Received().OpenPullRequest(prForBranch3);
gitHubOperations.Received().OpenPullRequest(prForBranch5);
gitHubOperations.Received().OpenPullRequest(prForBranch1);
gitHubOperations.Received().OpenPullRequest(prForBranch2);
}

[Fact]
public async Task WhenStackNameIsProvided_ButItStackDoesNotExist_Throws()
{
// Arrange
var gitOperations = Substitute.For<IGitOperations>();
var sourceBranch = Some.BranchName();
var branch1 = Some.BranchName();
var branch2 = Some.BranchName();
using var repo = new TestGitRepositoryBuilder()
.WithBranch(sourceBranch, true)
.WithBranch(branch1, true)
.WithBranch(branch2, true)
.Build();

var gitHubOperations = Substitute.For<IGitHubOperations>();
var stackConfig = Substitute.For<IStackConfig>();
var inputProvider = Substitute.For<IInputProvider>();
var outputProvider = Substitute.For<IOutputProvider>();
var fileOperations = Substitute.For<IFileOperations>();
var gitOperations = new GitOperations(outputProvider, repo.GitOperationSettings);
var handler = new OpenPullRequestsCommandHandler(inputProvider, outputProvider, gitOperations, gitHubOperations, stackConfig);

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

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

var stacks = 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, [branch1, branch2]),
new("Stack2", repo.RemoteUri, sourceBranch, [])
]);
stackConfig.Load().Returns(stacks);

var prForBranch3 = new GitHubPullRequest(1, "PR Title for branch-3", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-3")
.Returns(prForBranch3);

var prForBranch5 = new GitHubPullRequest(2, "PR Title for branch-5", string.Empty, GitHubPullRequestStates.Open, Some.HttpsUri(), false);
gitHubOperations
.GetPullRequest("branch-5")
.Returns(prForBranch5);

// Act and assert
var invalidStackName = Some.Name();
await handler.Invoking(h => h.Handle(new OpenPullRequestsCommandInputs(invalidStackName)))
Expand Down
Loading