| #!/bin/sh |
| |
| test_description='git checkout --patch' |
| . ./lib-patch-mode.sh |
| |
| test_expect_success PERL '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 PERL 'saying "n" does nothing' ' |
| set_state HEAD HEADfile_work HEADfile_index && |
| set_state dir/foo work index && |
| (echo n; echo n; echo 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 PERL 'git stash -p' ' |
| (echo y; echo n; echo 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 PERL '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 && |
| (echo y; echo n; echo 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 PERL '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 && |
| (echo y; echo n; echo 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 PERL 'none of this moved HEAD' ' |
| verify_saved_head |
| ' |
| |
| test_done |