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