feat(git): add MergeAbortAsync

This commit is contained in:
Mika Kuns
2026-04-22 09:29:24 +02:00
parent 3ebbdb3f6e
commit 21a1870fd7
2 changed files with 32 additions and 0 deletions

View File

@@ -129,4 +129,29 @@ public class GitServiceMergeTests : IDisposable
Assert.NotEqual(0, exitCode);
}
[Fact]
public async Task MergeAbortAsync_AfterConflict_ClearsMergeState()
{
if (!GitRepoFixture.IsGitAvailable()) return;
var repo = NewRepo();
GitRepoFixture.RunGit(repo.RepoDir, "checkout", "-b", "feature/abort");
File.WriteAllText(Path.Combine(repo.RepoDir, "README.md"), "# feat side\n");
GitRepoFixture.RunGit(repo.RepoDir, "add", "-A");
GitRepoFixture.RunGit(repo.RepoDir, "commit", "-m", "edit");
try { GitRepoFixture.RunGit(repo.RepoDir, "checkout", "main"); }
catch { GitRepoFixture.RunGit(repo.RepoDir, "checkout", "master"); }
File.WriteAllText(Path.Combine(repo.RepoDir, "README.md"), "# main side\n");
GitRepoFixture.RunGit(repo.RepoDir, "add", "-A");
GitRepoFixture.RunGit(repo.RepoDir, "commit", "-m", "edit");
var git = new GitService();
await git.MergeNoFfAsync(repo.RepoDir, "feature/abort", "merge"); // will conflict
Assert.True(await git.IsMidMergeAsync(repo.RepoDir));
await git.MergeAbortAsync(repo.RepoDir);
Assert.False(await git.IsMidMergeAsync(repo.RepoDir));
}
}