2009-08-15 13:48:30 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='git checkout --patch'
|
|
|
|
|
|
|
|
. ./lib-patch-mode.sh
|
|
|
|
|
add -i tests: mark "TODO" depending on GIT_TEST_ADD_I_USE_BUILTIN
Fix an issue that existed before 0527ccb1b55 (add -i: default to the
built-in implementation, 2021-11-30), but which became the default
with that change, we should not be marking tests that are known to
pass as "TODO" tests.
When GIT_TEST_ADD_I_USE_BUILTIN=1 was made the default we started
passing the tests added in 0f0fba2cc87 (t3701: add a test for advanced
split-hunk editing, 2019-12-06) and 1bf01040f0c (add -p: demonstrate
failure when running 'edit' after a split, 2015-04-16).
Thus we've been emitting this sort of output:
$ prove ./t3701-add-interactive.sh
./t3701-add-interactive.sh .. ok
All tests successful.
Test Summary Report
-------------------
./t3701-add-interactive.sh (Wstat: 0 Tests: 70 Failed: 0)
TODO passed: 45, 47
Files=1, Tests=70, 2 wallclock secs ( 0.03 usr 0.00 sys + 0.86 cusr 0.33 csys = 1.22 CPU)
Result: PASS
Which isn't just cosmetic, but due to issues with
test_expect_failure (see [1]) we could e.g. be hiding something as bad
as a segfault in the new implementation. It makes sense catch that,
especially before we put out a release with the built-in "add -i", so
let's generalize the check we were already doing in 0527ccb1b55 with a
new "ADD_I_USE_BUILTIN" prerequisite.
1. https://lore.kernel.org/git/patch-1.7-4624abc2591-20220318T002951Z-avarab@gmail.com/
Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2022-06-14 17:40:07 +02:00
|
|
|
if ! test_have_prereq ADD_I_USE_BUILTIN && ! test_have_prereq PERL
|
2021-11-30 15:14:14 +01:00
|
|
|
then
|
|
|
|
skip_all='skipping interactive add tests, PERL not set'
|
|
|
|
test_done
|
|
|
|
fi
|
|
|
|
|
|
|
|
test_expect_success 'setup' '
|
2009-08-15 13:48:30 +02:00
|
|
|
mkdir dir &&
|
|
|
|
echo parent > dir/foo &&
|
|
|
|
echo dummy > bar &&
|
|
|
|
git add bar dir/foo &&
|
|
|
|
git commit -m initial &&
|
|
|
|
test_tick &&
|
|
|
|
test_commit second dir/foo head &&
|
|
|
|
set_and_save_state bar bar_work bar_index &&
|
|
|
|
save_head
|
|
|
|
'
|
|
|
|
|
|
|
|
# note: bar sorts before dir/foo, so the first 'n' is always to skip 'bar'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'saying "n" does nothing' '
|
2009-08-15 13:48:30 +02:00
|
|
|
set_and_save_state dir/foo work head &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n n | git checkout -p &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_saved_state dir/foo
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p' '
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y | git checkout -p &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p with staged changes' '
|
2010-10-31 02:46:54 +01:00
|
|
|
set_state dir/foo work index &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y | git checkout -p &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo index index
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p HEAD with NO staged changes: abort' '
|
2009-08-15 13:48:30 +02:00
|
|
|
set_and_save_state dir/foo work head &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y n | git checkout -p HEAD &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_saved_state dir/foo
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p HEAD with NO staged changes: apply' '
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y y | git checkout -p HEAD &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p HEAD with change already staged' '
|
2010-09-07 10:22:53 +02:00
|
|
|
set_state dir/foo index index &&
|
2009-08-15 13:48:30 +02:00
|
|
|
# the third n is to get out in case it mistakenly does not apply
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y n | git checkout -p HEAD &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p HEAD^...' '
|
2020-10-07 09:56:15 +02:00
|
|
|
# the third n is to get out in case it mistakenly does not apply
|
|
|
|
test_write_lines n y n | git checkout -p HEAD^... &&
|
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo parent parent
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p HEAD^' '
|
2009-08-15 13:48:30 +02:00
|
|
|
# the third n is to get out in case it mistakenly does not apply
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y n | git checkout -p HEAD^ &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo parent parent
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'git checkout -p handles deletion' '
|
add-interactive: fix bogus diff header line ordering
When we look at a patch for adding hunks interactively, we
first split it into a header and a list of hunks. Some of
the header lines, such as mode changes and deletion, however,
become their own selectable hunks. Later when we reassemble
the patch, we simply concatenate the header and the selected
hunks. This leads to patches like this:
diff --git a/file b/file
index d95f3ad..0000000
--- a/file
+++ /dev/null
deleted file mode 100644
@@ -1 +0,0 @@
-content
Notice how the deletion comes _after_ the ---/+++ lines,
when it should come before.
In many cases, we can get away with this as git-apply
accepts the slightly bogus input. However, in the specific
case of a deletion line that is being applied via "apply
-R", this malformed patch triggers an assert in git-apply.
This comes up when discarding a deletion via "git checkout
-p".
Rather than try to make git-apply accept our odd input,
let's just reassemble the patch in the correct order.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2010-02-23 02:05:44 +01:00
|
|
|
set_state dir/foo work index &&
|
|
|
|
rm dir/foo &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines n y | git checkout -p &&
|
add-interactive: fix bogus diff header line ordering
When we look at a patch for adding hunks interactively, we
first split it into a header and a list of hunks. Some of
the header lines, such as mode changes and deletion, however,
become their own selectable hunks. Later when we reassemble
the patch, we simply concatenate the header and the selected
hunks. This leads to patches like this:
diff --git a/file b/file
index d95f3ad..0000000
--- a/file
+++ /dev/null
deleted file mode 100644
@@ -1 +0,0 @@
-content
Notice how the deletion comes _after_ the ---/+++ lines,
when it should come before.
In many cases, we can get away with this as git-apply
accepts the slightly bogus input. However, in the specific
case of a deletion line that is being applied via "apply
-R", this malformed patch triggers an assert in git-apply.
This comes up when discarding a deletion via "git checkout
-p".
Rather than try to make git-apply accept our odd input,
let's just reassemble the patch in the correct order.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2010-02-23 02:05:44 +01:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo index index
|
|
|
|
'
|
|
|
|
|
2009-08-15 13:48:30 +02:00
|
|
|
# The idea in the rest is that bar sorts first, so we always say 'y'
|
|
|
|
# first and if the path limiter fails it'll apply to bar instead of
|
|
|
|
# dir/foo. There's always an extra 'n' to reject edits to dir/foo in
|
|
|
|
# the failure case (and thus get out of the loop).
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'path limiting works: dir' '
|
2009-08-15 13:48:30 +02:00
|
|
|
set_state dir/foo work head &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines y n | git checkout -p dir &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'path limiting works: -- dir' '
|
2009-08-15 13:48:30 +02:00
|
|
|
set_state dir/foo work head &&
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines y n | git checkout -p -- dir &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'path limiting works: HEAD^ -- dir' '
|
2009-08-15 13:48:30 +02:00
|
|
|
# the third n is to get out in case it mistakenly does not apply
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines y n n | git checkout -p HEAD^ -- dir &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo parent parent
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'path limiting works: foo inside dir' '
|
2009-08-15 13:48:30 +02:00
|
|
|
set_state dir/foo work head &&
|
|
|
|
# the third n is to get out in case it mistakenly does not apply
|
2018-07-02 02:23:42 +02:00
|
|
|
test_write_lines y n n | (cd dir && git checkout -p foo) &&
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_state bar &&
|
|
|
|
verify_state dir/foo head head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'none of this moved HEAD' '
|
2009-08-15 13:48:30 +02:00
|
|
|
verify_saved_head
|
|
|
|
'
|
|
|
|
|
2021-11-30 15:14:14 +01:00
|
|
|
test_expect_success 'empty tree can be handled' '
|
2020-12-19 15:55:59 +01:00
|
|
|
test_when_finished "git reset --hard" &&
|
|
|
|
git checkout -p $(test_oid empty_tree) --
|
|
|
|
'
|
|
|
|
|
2009-08-15 13:48:30 +02:00
|
|
|
test_done
|