t3404: demonstrate CHERRY_PICK_HEAD bug
When rev-list's --cherry option does not detect that a patch has already been applied upstream, an interactive rebase would offer to reapply it and consequently stop at that patch with a failure, mentioning that the diff is empty. Traditionally, a `git rebase --continue` simply skips the commit in such a situation. However, as pointed out by Gábor Szeder, this leaves a CHERRY_PICK_HEAD behind, making the Git prompt believe that a cherry pick is still going on. This commit adds a test case demonstrating this bug. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
fdf96a20ac
commit
d17ec3a9da
@ -1039,4 +1039,25 @@ test_expect_success 'short SHA-1 collide' '
|
||||
)
|
||||
'
|
||||
|
||||
test_expect_failure 'rebase --continue removes CHERRY_PICK_HEAD' '
|
||||
git checkout -b commit-to-skip &&
|
||||
for double in X 3 1
|
||||
do
|
||||
test_seq 5 | sed "s/$double/&&/" >seq &&
|
||||
git add seq &&
|
||||
test_tick &&
|
||||
git commit -m seq-$double
|
||||
done &&
|
||||
git tag seq-onto &&
|
||||
git reset --hard HEAD~2 &&
|
||||
git cherry-pick seq-onto &&
|
||||
set_fake_editor &&
|
||||
test_must_fail env FAKE_LINES= git rebase -i seq-onto &&
|
||||
test -d .git/rebase-merge &&
|
||||
git rebase --continue &&
|
||||
git diff --exit-code seq-onto &&
|
||||
test ! -d .git/rebase-merge &&
|
||||
test ! -f .git/CHERRY_PICK_HEAD
|
||||
'
|
||||
|
||||
test_done
|
||||
|
Loading…
Reference in New Issue
Block a user