forked from mystor/git-revise
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Commit reordering: Avoid asking about the same conflict twice
Implements mystor#132
- Loading branch information
Showing
5 changed files
with
48 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -36,12 +36,10 @@ def test_reuse_recorded_resolution( | |
history_with_two_conflicting_commits(auto_update=auto_update) | ||
|
||
# Uncached case: Record the user's resolution (in .git/rr-cache/*/preimage). | ||
with editor_main(("-i", "HEAD~~"), input=b"y\n" * 4) as ed: | ||
with editor_main(("-i", "HEAD~~"), input=b"y\n" * 2) as ed: | ||
flip_last_two_commits(repo, ed) | ||
with ed.next_file() as f: | ||
f.replace_dedent("spam\n") | ||
with ed.next_file() as f: | ||
f.replace_dedent("eggs spam\n") | ||
|
||
tree_after_resolving_conflicts = repo.get_commit("HEAD").tree() | ||
bash("git reset --hard HEAD@{1}") | ||
|
@@ -50,18 +48,16 @@ def test_reuse_recorded_resolution( | |
acceptance_input = None | ||
intermediate_state = "spam" | ||
if not auto_update: | ||
acceptance_input = b"y\n" * 2 | ||
acceptance_input = b"y\n" | ||
if custom_resolution is not None: | ||
acceptance_input = b"n\n" + b"y\n" * 4 | ||
acceptance_input = b"n\n" + b"y\n" * 2 | ||
intermediate_state = custom_resolution | ||
|
||
with editor_main(("-i", "HEAD~~"), input=acceptance_input) as ed: | ||
flip_last_two_commits(repo, ed) | ||
if custom_resolution is not None: | ||
with ed.next_file() as f: | ||
f.replace_dedent(custom_resolution + "\n") | ||
with ed.next_file() as f: | ||
f.replace_dedent("eggs spam\n") | ||
|
||
assert tree_after_resolving_conflicts == repo.get_commit("HEAD").tree() | ||
|
||
|
@@ -95,12 +91,10 @@ def test_rerere_merge(repo: Repository) -> None: | |
bash("git commit -am 'commit 2'") | ||
|
||
# Record a resolution for changing the order of two commits. | ||
with editor_main(("-i", "HEAD~~"), input=b"y\ny\ny\ny\n") as ed: | ||
with editor_main(("-i", "HEAD~~"), input=b"y\ny\n") as ed: | ||
flip_last_two_commits(repo, ed) | ||
with ed.next_file() as f: | ||
f.replace_dedent(b"resolved1\n" + 9 * b"x\n") | ||
with ed.next_file() as f: | ||
f.replace_dedent(b"resolved2\n" + 9 * b"x\n") | ||
# Go back to the old history so we can try replaying the resolution. | ||
bash("git reset --hard HEAD@{1}") | ||
|
||
|
@@ -123,15 +117,9 @@ def test_rerere_merge(repo: Repository) -> None: | |
"""\ | ||
@@ -1 +1 @@ | ||
-resolved1 | ||
+resolved2""" | ||
) | ||
leftover_index = hunks(repo.git("diff", "-U0", "HEAD")) | ||
assert leftover_index == dedent( | ||
"""\ | ||
@@ -1 +1 @@ | ||
-resolved2 | ||
+original2""" | ||
+original2""" | ||
) | ||
assert leftover_index(repo.git("diff", "-U0", "HEAD")) == "" | ||
|
||
|
||
def test_replay_resolution_recorded_by_git(repo: Repository) -> None: | ||
|
@@ -151,25 +139,28 @@ def test_replay_resolution_recorded_by_git(repo: Repository) -> None: | |
""" | ||
) | ||
|
||
# Now let's try to do the same thing with git-revise, reusing the recorded resolution. | ||
# Git-revise may well reuse an intermediate state resolution, | ||
# but actually knows that nobody expects the final state to change | ||
# when just changing the order it's done: Whenever the final state | ||
# is known, that pointless second conflict is bypassed. | ||
with editor_main(("-i", "HEAD~~")) as ed: | ||
flip_last_two_commits(repo, ed) | ||
|
||
assert repo.git("log", "-p", trim_newline=False).decode() == dedent( | ||
"""\ | ||
commit 44fdce0cf7ae75ed5edac5f3defed83cddf3ec4a | ||
commit 31aa1057aca9f039e997fff9396fb9656fb4c01c | ||
Author: Bash Author <[email protected]> | ||
Date: Thu Jul 13 21:40:00 2017 -0500 | ||
add eggs | ||
diff --git a/file b/file | ||
index 5d0f8a8..cb90548 100644 | ||
index 5d0f8a8..2481b83 100644 | ||
--- a/file | ||
+++ b/file | ||
@@ -1 +1 @@ | ||
-intermediate state | ||
+something completely different | ||
+eggs spam | ||
commit 1fa5135a6cce1f63dc2f5584ee68e15a4de3a99c | ||
Author: Bash Author <[email protected]> | ||
|