116 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
| #!/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
 |