feat(git): add MergeAbortAsync
This commit is contained in:
@@ -191,6 +191,13 @@ public sealed class GitService
|
||||
return (exitCode, stderr);
|
||||
}
|
||||
|
||||
public async Task MergeAbortAsync(string repoDir, CancellationToken ct = default)
|
||||
{
|
||||
var (exitCode, _, stderr) = await RunGitAsync(repoDir, ["merge", "--abort"], ct);
|
||||
if (exitCode != 0)
|
||||
throw new InvalidOperationException($"git merge --abort failed (exit {exitCode}): {stderr}");
|
||||
}
|
||||
|
||||
public async Task MergeFfOnlyAsync(string repoDir, string branchName, CancellationToken ct = default)
|
||||
{
|
||||
var (exitCode, _, stderr) = await RunGitAsync(repoDir, ["merge", "--ff-only", branchName], ct);
|
||||
|
||||
@@ -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));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user