af316cb40b7b16c95881eb8483eea4f6191c7cfa
1#!/bin/sh
2
3test_description='cherry-pick should rerere for conflicts'
4
5. ./test-lib.sh
6
7test_expect_success setup '
8 test_commit foo &&
9 test_commit foo-master foo &&
10 test_commit bar-master bar &&
11
12 git checkout -b dev foo &&
13 test_commit foo-dev foo &&
14 test_commit bar-dev bar &&
15 git config rerere.enabled true
16'
17
18test_expect_success 'conflicting merge' '
19 test_must_fail git merge master
20'
21
22test_expect_success 'fixup' '
23 echo foo-resolved >foo &&
24 echo bar-resolved >bar &&
25 git commit -am resolved &&
26 cp foo foo-expect &&
27 cp bar bar-expect &&
28 git reset --hard HEAD^
29'
30
31test_expect_success 'cherry-pick conflict with --rerere-autoupdate' '
32 test_must_fail git cherry-pick --rerere-autoupdate foo..bar-master &&
33 test_cmp foo-expect foo &&
34 git diff-files --quiet &&
35 test_must_fail git cherry-pick --continue &&
36 test_cmp bar-expect bar &&
37 git diff-files --quiet &&
38 git cherry-pick --continue &&
39 git reset --hard bar-dev
40'
41
42test_expect_success 'cherry-pick conflict repsects rerere.autoUpdate' '
43 test_config rerere.autoUpdate true &&
44 test_must_fail git cherry-pick foo..bar-master &&
45 test_cmp foo-expect foo &&
46 git diff-files --quiet &&
47 test_must_fail git cherry-pick --continue &&
48 test_cmp bar-expect bar &&
49 git diff-files --quiet &&
50 git cherry-pick --continue &&
51 git reset --hard bar-dev
52'
53
54test_expect_success 'cherry-pick conflict with --no-rerere-autoupdate' '
55 test_config rerere.autoUpdate true &&
56 test_must_fail git cherry-pick --no-rerere-autoupdate foo..bar-master &&
57 test_cmp foo-expect foo &&
58 test_must_fail git diff-files --quiet &&
59 git add foo &&
60 test_must_fail git cherry-pick --continue &&
61 test_cmp bar-expect bar &&
62 test_must_fail git diff-files --quiet &&
63 git add bar &&
64 git cherry-pick --continue &&
65 git reset --hard bar-dev
66'
67
68test_expect_success 'cherry-pick --rerere-autoupdate more than once' '
69 test_must_fail git cherry-pick --rerere-autoupdate --rerere-autoupdate foo..bar-master &&
70 test_cmp foo-expect foo &&
71 git diff-files --quiet &&
72 git cherry-pick --abort &&
73 test_must_fail git cherry-pick --rerere-autoupdate --no-rerere-autoupdate --rerere-autoupdate foo..bar-master &&
74 test_cmp foo-expect foo &&
75 git diff-files --quiet &&
76 git cherry-pick --abort &&
77 test_must_fail git cherry-pick --rerere-autoupdate --no-rerere-autoupdate foo..bar-master &&
78 test_must_fail git diff-files --quiet &&
79 git cherry-pick --abort
80'
81
82test_expect_success 'cherry-pick conflict without rerere' '
83 test_config rerere.enabled false &&
84 test_must_fail git cherry-pick master &&
85 test_must_fail test_cmp expect foo
86'
87
88test_done