]>
Commit | Line | Data |
---|---|---|
04d3d3cf RR |
1 | #!/bin/sh |
2 | ||
3 | test_description='Test cherry-pick continuation features | |
4 | ||
5 | + anotherpick: rewrites foo to d | |
6 | + picked: rewrites foo to c | |
7 | + unrelatedpick: rewrites unrelated to reallyunrelated | |
8 | + base: rewrites foo to b | |
9 | + initial: writes foo as a, unrelated as unrelated | |
10 | ||
11 | ' | |
12 | ||
13 | . ./test-lib.sh | |
14 | ||
15 | pristine_detach () { | |
26ae337b | 16 | git cherry-pick --reset && |
04d3d3cf RR |
17 | git checkout -f "$1^0" && |
18 | git read-tree -u --reset HEAD && | |
19 | git clean -d -f -f -q -x | |
20 | } | |
21 | ||
22 | test_expect_success setup ' | |
23 | echo unrelated >unrelated && | |
24 | git add unrelated && | |
25 | test_commit initial foo a && | |
26 | test_commit base foo b && | |
27 | test_commit unrelatedpick unrelated reallyunrelated && | |
28 | test_commit picked foo c && | |
29 | test_commit anotherpick foo d && | |
30 | git config advice.detachedhead false | |
31 | ||
32 | ' | |
33 | ||
34 | test_expect_success 'cherry-pick persists data on failure' ' | |
35 | pristine_detach initial && | |
6f032263 | 36 | test_must_fail git cherry-pick -s base..anotherpick && |
04d3d3cf RR |
37 | test_path_is_dir .git/sequencer && |
38 | test_path_is_file .git/sequencer/head && | |
6f032263 RR |
39 | test_path_is_file .git/sequencer/todo && |
40 | test_path_is_file .git/sequencer/opts | |
41 | ' | |
42 | ||
43 | test_expect_success 'cherry-pick persists opts correctly' ' | |
44 | pristine_detach initial && | |
45 | test_must_fail git cherry-pick -s -m 1 --strategy=recursive -X patience -X ours base..anotherpick && | |
46 | test_path_is_dir .git/sequencer && | |
47 | test_path_is_file .git/sequencer/head && | |
48 | test_path_is_file .git/sequencer/todo && | |
49 | test_path_is_file .git/sequencer/opts && | |
50 | echo "true" >expect && | |
51 | git config --file=.git/sequencer/opts --get-all options.signoff >actual && | |
52 | test_cmp expect actual && | |
53 | echo "1" >expect && | |
54 | git config --file=.git/sequencer/opts --get-all options.mainline >actual && | |
55 | test_cmp expect actual && | |
56 | echo "recursive" >expect && | |
57 | git config --file=.git/sequencer/opts --get-all options.strategy >actual && | |
58 | test_cmp expect actual && | |
59 | cat >expect <<-\EOF && | |
60 | patience | |
61 | ours | |
62 | EOF | |
63 | git config --file=.git/sequencer/opts --get-all options.strategy-option >actual && | |
64 | test_cmp expect actual | |
04d3d3cf RR |
65 | ' |
66 | ||
67 | test_expect_success 'cherry-pick cleans up sequencer state upon success' ' | |
68 | pristine_detach initial && | |
69 | git cherry-pick initial..picked && | |
70 | test_path_is_missing .git/sequencer | |
71 | ' | |
72 | ||
26ae337b RR |
73 | test_expect_success '--reset does not complain when no cherry-pick is in progress' ' |
74 | pristine_detach initial && | |
75 | git cherry-pick --reset | |
76 | ' | |
77 | ||
78 | test_expect_success '--reset cleans up sequencer state' ' | |
79 | pristine_detach initial && | |
80 | test_must_fail git cherry-pick base..picked && | |
81 | git cherry-pick --reset && | |
82 | test_path_is_missing .git/sequencer | |
83 | ' | |
84 | ||
2d27daa9 RR |
85 | test_expect_success 'cherry-pick cleans up sequencer state when one commit is left' ' |
86 | pristine_detach initial && | |
87 | test_must_fail git cherry-pick base..picked && | |
88 | test_path_is_missing .git/sequencer && | |
89 | echo "resolved" >foo && | |
90 | git add foo && | |
91 | git commit && | |
92 | { | |
93 | git rev-list HEAD | | |
94 | git diff-tree --root --stdin | | |
95 | sed "s/$_x40/OBJID/g" | |
96 | } >actual && | |
97 | cat >expect <<-\EOF && | |
98 | OBJID | |
99 | :100644 100644 OBJID OBJID M foo | |
100 | OBJID | |
101 | :100644 100644 OBJID OBJID M unrelated | |
102 | OBJID | |
103 | :000000 100644 OBJID OBJID A foo | |
104 | :000000 100644 OBJID OBJID A unrelated | |
105 | EOF | |
106 | test_cmp expect actual | |
107 | ' | |
108 | ||
21afd080 RR |
109 | test_expect_success 'cherry-pick does not implicitly stomp an existing operation' ' |
110 | pristine_detach initial && | |
111 | test_must_fail git cherry-pick base..anotherpick && | |
112 | test-chmtime -v +0 .git/sequencer >expect && | |
113 | test_must_fail git cherry-pick unrelatedpick && | |
114 | test-chmtime -v +0 .git/sequencer >actual && | |
115 | test_cmp expect actual | |
116 | ' | |
117 | ||
04d3d3cf | 118 | test_done |