summaryrefslogtreecommitdiff
path: root/t
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <gitster@pobox.com>2008-08-27 16:40:09 -0700
committerLibravatar Junio C Hamano <gitster@pobox.com>2008-08-27 16:40:09 -0700
commit88ab18dfef55a41df2e1f69a8ab3e3ed9f915c31 (patch)
treeb4550d79e5f34a8817ea787b299cabf8174c81c6 /t
parentMerge branch 'jc/add-addremove' (diff)
parentMake cherry-pick use rerere for conflict resolution. (diff)
downloadtgif-88ab18dfef55a41df2e1f69a8ab3e3ed9f915c31.tar.xz
Merge branch 'am/cherry-pick-rerere'
* am/cherry-pick-rerere: Make cherry-pick use rerere for conflict resolution.
Diffstat (limited to 't')
-rwxr-xr-xt/t3504-cherry-pick-rerere.sh45
1 files changed, 45 insertions, 0 deletions
diff --git a/t/t3504-cherry-pick-rerere.sh b/t/t3504-cherry-pick-rerere.sh
new file mode 100755
index 0000000000..f7b3518a32
--- /dev/null
+++ b/t/t3504-cherry-pick-rerere.sh
@@ -0,0 +1,45 @@
+#!/bin/sh
+
+test_description='cherry-pick should rerere for conflicts'
+
+. ./test-lib.sh
+
+test_expect_success setup '
+ echo foo >foo &&
+ git add foo && test_tick && git commit -q -m 1 &&
+ echo foo-master >foo &&
+ git add foo && test_tick && git commit -q -m 2 &&
+
+ git checkout -b dev HEAD^ &&
+ echo foo-dev >foo &&
+ git add foo && test_tick && git commit -q -m 3 &&
+ git config rerere.enabled true
+'
+
+test_expect_success 'conflicting merge' '
+ test_must_fail git merge master
+'
+
+test_expect_success 'fixup' '
+ echo foo-dev >foo &&
+ git add foo && test_tick && git commit -q -m 4 &&
+ git reset --hard HEAD^
+ echo foo-dev >expect
+'
+
+test_expect_success 'cherry-pick conflict' '
+ test_must_fail git cherry-pick master &&
+ test_cmp expect foo
+'
+
+test_expect_success 'reconfigure' '
+ git config rerere.enabled false
+ git reset --hard
+'
+
+test_expect_success 'cherry-pick conflict without rerere' '
+ test_must_fail git cherry-pick master &&
+ test_must_fail test_cmp expect foo
+'
+
+test_done