|  | #!/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 && | 
|  | (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 '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 '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 '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 '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 |