]>
Commit | Line | Data |
---|---|---|
d002ef4d TR |
1 | #!/bin/sh |
2 | ||
3 | test_description='git reset --patch' | |
4 | . ./lib-patch-mode.sh | |
5 | ||
d2b263cb | 6 | test_expect_success PERL 'setup' ' |
d002ef4d TR |
7 | mkdir dir && |
8 | echo parent > dir/foo && | |
9 | echo dummy > bar && | |
10 | git add dir && | |
11 | git commit -m initial && | |
12 | test_tick && | |
13 | test_commit second dir/foo head && | |
14 | set_and_save_state bar bar_work bar_index && | |
15 | save_head | |
16 | ' | |
17 | ||
18 | # note: bar sorts before foo, so the first 'n' is always to skip 'bar' | |
19 | ||
d2b263cb | 20 | test_expect_success PERL 'saying "n" does nothing' ' |
a48fcd83 | 21 | set_and_save_state dir/foo work work && |
0590ff26 | 22 | test_write_lines n n | git reset -p && |
d002ef4d TR |
23 | verify_saved_state dir/foo && |
24 | verify_saved_state bar | |
25 | ' | |
26 | ||
d2b263cb | 27 | test_expect_success PERL 'git reset -p' ' |
0590ff26 | 28 | test_write_lines n y | git reset -p >output && |
d002ef4d | 29 | verify_state dir/foo work head && |
b3e9ce13 JK |
30 | verify_saved_state bar && |
31 | test_i18ngrep "Unstage" output | |
d002ef4d TR |
32 | ' |
33 | ||
d2b263cb | 34 | test_expect_success PERL 'git reset -p HEAD^' ' |
0590ff26 | 35 | test_write_lines n y | git reset -p HEAD^ >output && |
d002ef4d | 36 | verify_state dir/foo work parent && |
b3e9ce13 JK |
37 | verify_saved_state bar && |
38 | test_i18ngrep "Apply" output | |
d002ef4d TR |
39 | ' |
40 | ||
0a8e3036 NL |
41 | test_expect_success PERL 'git reset -p HEAD^^{tree}' ' |
42 | test_write_lines n y | git reset -p HEAD^^{tree} >output && | |
43 | verify_state dir/foo work parent && | |
44 | verify_saved_state bar && | |
45 | test_i18ngrep "Apply" output | |
46 | ' | |
47 | ||
48 | test_expect_success PERL 'git reset -p HEAD^:dir/foo (blob fails)' ' | |
49 | set_and_save_state dir/foo work work && | |
50 | test_must_fail git reset -p HEAD^:dir/foo && | |
51 | verify_saved_state dir/foo && | |
52 | verify_saved_state bar | |
53 | ' | |
54 | ||
55 | test_expect_success PERL 'git reset -p aaaaaaaa (unknown fails)' ' | |
56 | set_and_save_state dir/foo work work && | |
57 | test_must_fail git reset -p aaaaaaaa && | |
58 | verify_saved_state dir/foo && | |
59 | verify_saved_state bar | |
60 | ' | |
61 | ||
d002ef4d TR |
62 | # The idea in the rest is that bar sorts first, so we always say 'y' |
63 | # first and if the path limiter fails it'll apply to bar instead of | |
64 | # dir/foo. There's always an extra 'n' to reject edits to dir/foo in | |
65 | # the failure case (and thus get out of the loop). | |
66 | ||
f2f7b6a5 | 67 | test_expect_success PERL 'git reset -p dir' ' |
a48fcd83 | 68 | set_state dir/foo work work && |
0590ff26 | 69 | test_write_lines y n | git reset -p dir && |
d002ef4d TR |
70 | verify_state dir/foo work head && |
71 | verify_saved_state bar | |
72 | ' | |
73 | ||
f2f7b6a5 | 74 | test_expect_success PERL 'git reset -p -- foo (inside dir)' ' |
a48fcd83 | 75 | set_state dir/foo work work && |
0590ff26 | 76 | test_write_lines y n | (cd dir && git reset -p -- foo) && |
d002ef4d TR |
77 | verify_state dir/foo work head && |
78 | verify_saved_state bar | |
79 | ' | |
80 | ||
f2f7b6a5 | 81 | test_expect_success PERL 'git reset -p HEAD^ -- dir' ' |
0590ff26 | 82 | test_write_lines y n | git reset -p HEAD^ -- dir && |
d002ef4d TR |
83 | verify_state dir/foo work parent && |
84 | verify_saved_state bar | |
85 | ' | |
86 | ||
f2f7b6a5 | 87 | test_expect_success PERL 'none of this moved HEAD' ' |
d002ef4d TR |
88 | verify_saved_head |
89 | ' | |
90 | ||
91 | ||
92 | test_done |