You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
2.9 KiB
115 lines
2.9 KiB
#!/bin/sh |
|
|
|
test_description='stash -p' |
|
. ./lib-patch-mode.sh |
|
|
|
if ! test_have_prereq PERL |
|
then |
|
skip_all='skipping stash -p tests, perl not available' |
|
test_done |
|
fi |
|
|
|
test_expect_success 'setup' ' |
|
mkdir dir && |
|
echo parent > dir/foo && |
|
echo dummy > bar && |
|
echo committed > HEAD && |
|
git add bar dir/foo HEAD && |
|
git commit -m initial && |
|
test_tick && |
|
test_commit second dir/foo head && |
|
echo index > dir/foo && |
|
git add dir/foo && |
|
set_and_save_state bar bar_work bar_index && |
|
save_head |
|
' |
|
|
|
# note: order of files with unstaged changes: HEAD bar dir/foo |
|
|
|
test_expect_success 'saying "n" does nothing' ' |
|
set_state HEAD HEADfile_work HEADfile_index && |
|
set_state dir/foo work index && |
|
test_write_lines n n n | test_must_fail git stash save -p && |
|
verify_state HEAD HEADfile_work HEADfile_index && |
|
verify_saved_state bar && |
|
verify_state dir/foo work index |
|
' |
|
|
|
test_expect_success 'git stash -p' ' |
|
test_write_lines y n y | git stash save -p && |
|
verify_state HEAD committed HEADfile_index && |
|
verify_saved_state bar && |
|
verify_state dir/foo head index && |
|
git reset --hard && |
|
git stash apply && |
|
verify_state HEAD HEADfile_work committed && |
|
verify_state bar dummy dummy && |
|
verify_state dir/foo work head |
|
' |
|
|
|
test_expect_success 'git stash -p --no-keep-index' ' |
|
set_state HEAD HEADfile_work HEADfile_index && |
|
set_state bar bar_work bar_index && |
|
set_state dir/foo work index && |
|
test_write_lines y n y | git stash save -p --no-keep-index && |
|
verify_state HEAD committed committed && |
|
verify_state bar bar_work dummy && |
|
verify_state dir/foo head head && |
|
git reset --hard && |
|
git stash apply --index && |
|
verify_state HEAD HEADfile_work HEADfile_index && |
|
verify_state bar dummy bar_index && |
|
verify_state dir/foo work index |
|
' |
|
|
|
test_expect_success 'git stash --no-keep-index -p' ' |
|
set_state HEAD HEADfile_work HEADfile_index && |
|
set_state bar bar_work bar_index && |
|
set_state dir/foo work index && |
|
test_write_lines y n y | git stash save --no-keep-index -p && |
|
verify_state HEAD committed committed && |
|
verify_state dir/foo head head && |
|
verify_state bar bar_work dummy && |
|
git reset --hard && |
|
git stash apply --index && |
|
verify_state HEAD HEADfile_work HEADfile_index && |
|
verify_state bar dummy bar_index && |
|
verify_state dir/foo work index |
|
' |
|
|
|
test_expect_success 'stash -p --no-keep-index -- <pathspec> does not unstage other files' ' |
|
set_state HEAD HEADfile_work HEADfile_index && |
|
set_state dir/foo work index && |
|
echo y | git stash push -p --no-keep-index -- HEAD && |
|
verify_state HEAD committed committed && |
|
verify_state dir/foo work index |
|
' |
|
|
|
test_expect_success 'none of this moved HEAD' ' |
|
verify_saved_head |
|
' |
|
|
|
test_expect_failure 'stash -p with split hunk' ' |
|
git reset --hard && |
|
cat >test <<-\EOF && |
|
aaa |
|
bbb |
|
ccc |
|
EOF |
|
git add test && |
|
git commit -m "initial" && |
|
cat >test <<-\EOF && |
|
aaa |
|
added line 1 |
|
bbb |
|
added line 2 |
|
ccc |
|
EOF |
|
printf "%s\n" s n y q | |
|
test_might_fail git stash -p 2>error && |
|
! test_must_be_empty error && |
|
grep "added line 1" test && |
|
! grep "added line 2" test |
|
' |
|
|
|
test_done
|
|
|