]>
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 | ||
41 | # The idea in the rest is that bar sorts first, so we always say 'y' | |
42 | # first and if the path limiter fails it'll apply to bar instead of | |
43 | # dir/foo. There's always an extra 'n' to reject edits to dir/foo in | |
44 | # the failure case (and thus get out of the loop). | |
45 | ||
f2f7b6a5 | 46 | test_expect_success PERL 'git reset -p dir' ' |
a48fcd83 | 47 | set_state dir/foo work work && |
0590ff26 | 48 | test_write_lines y n | git reset -p dir && |
d002ef4d TR |
49 | verify_state dir/foo work head && |
50 | verify_saved_state bar | |
51 | ' | |
52 | ||
f2f7b6a5 | 53 | test_expect_success PERL 'git reset -p -- foo (inside dir)' ' |
a48fcd83 | 54 | set_state dir/foo work work && |
0590ff26 | 55 | test_write_lines y n | (cd dir && git reset -p -- foo) && |
d002ef4d TR |
56 | verify_state dir/foo work head && |
57 | verify_saved_state bar | |
58 | ' | |
59 | ||
f2f7b6a5 | 60 | test_expect_success PERL 'git reset -p HEAD^ -- dir' ' |
0590ff26 | 61 | test_write_lines y n | git reset -p HEAD^ -- dir && |
d002ef4d TR |
62 | verify_state dir/foo work parent && |
63 | verify_saved_state bar | |
64 | ' | |
65 | ||
f2f7b6a5 | 66 | test_expect_success PERL 'none of this moved HEAD' ' |
d002ef4d TR |
67 | verify_saved_head |
68 | ' | |
69 | ||
70 | ||
71 | test_done |