| #!/bin/sh | 
 |  | 
 | last_shelved_change () { | 
 | 	p4 changes -s shelved -m1 | cut -d " " -f 2 | 
 | } | 
 |  | 
 | test_description='git p4 unshelve' | 
 |  | 
 | . ./lib-git-p4.sh | 
 |  | 
 | test_expect_success 'start p4d' ' | 
 | 	start_p4d | 
 | ' | 
 |  | 
 | test_expect_success 'init depot' ' | 
 | 	( | 
 | 		cd "$cli" && | 
 | 		echo file1 >file1 && | 
 | 		p4 add file1 && | 
 | 		p4 submit -d "change 1" && | 
 | 		: >file_to_delete && | 
 | 		: >file_to_move && | 
 | 		p4 add file_to_delete && | 
 | 		p4 add file_to_move && | 
 | 		p4 submit -d "add files to delete" && | 
 | 		echo file_to_integrate >file_to_integrate && | 
 | 		p4 add file_to_integrate && | 
 | 		p4 submit -d "add file to integrate" | 
 | 	) | 
 | ' | 
 |  | 
 | # Create an initial clone, with a commit unrelated to the P4 change | 
 | # on HEAD | 
 | test_expect_success 'initial clone' ' | 
 | 	git p4 clone --dest="$git" //depot/@all && | 
 |     test_commit -C "$git" "unrelated" | 
 | ' | 
 |  | 
 | test_expect_success 'create shelved changelist' ' | 
 | 	( | 
 | 		cd "$cli" && | 
 | 		p4 edit file1 && | 
 | 		echo "a change" >>file1 && | 
 | 		echo "new file" >file2 && | 
 | 		p4 add file2 && | 
 | 		p4 delete file_to_delete && | 
 | 		p4 edit file_to_move && | 
 | 		p4 move file_to_move moved_file && | 
 | 		p4 integrate file_to_integrate integrated_file && | 
 | 		p4 opened && | 
 | 		p4 shelve -i <<EOF | 
 | Change: new | 
 | Description: | 
 | 	Test commit | 
 |  | 
 | 	Further description | 
 | Files: | 
 | 	//depot/file1 | 
 | 	//depot/file2 | 
 | 	//depot/file_to_delete | 
 | 	//depot/file_to_move | 
 | 	//depot/moved_file | 
 | 	//depot/integrated_file | 
 | EOF | 
 |  | 
 | 	) && | 
 | 	( | 
 | 		cd "$git" && | 
 | 		change=$(last_shelved_change) && | 
 | 		git p4 unshelve $change && | 
 | 		git show refs/remotes/p4-unshelved/$change >actual && | 
 | 		grep -q "Further description" actual && | 
 | 		git cherry-pick refs/remotes/p4-unshelved/$change && | 
 | 		test_path_is_file file2 && | 
 | 		test_cmp file1 "$cli"/file1 && | 
 | 		test_cmp file2 "$cli"/file2 && | 
 | 		test_cmp file_to_integrate "$cli"/integrated_file && | 
 | 		test_path_is_missing file_to_delete && | 
 | 		test_path_is_missing file_to_move && | 
 | 		test_path_is_file moved_file | 
 | 	) | 
 | ' | 
 |  | 
 | test_expect_success 'update shelved changelist and re-unshelve' ' | 
 | 	test_when_finished cleanup_git && | 
 | 	( | 
 | 		cd "$cli" && | 
 | 		change=$(last_shelved_change) && | 
 | 		echo "file3" >file3 && | 
 | 		p4 add -c $change file3 && | 
 | 		p4 shelve -i -r <<EOF && | 
 | Change: $change | 
 | Description: | 
 | 	Test commit | 
 |  | 
 | 	Further description | 
 | Files: | 
 | 	//depot/file1 | 
 | 	//depot/file2 | 
 | 	//depot/file3 | 
 | 	//depot/file_to_delete | 
 | EOF | 
 | 		p4 describe $change | 
 | 	) && | 
 | 	( | 
 | 		cd "$git" && | 
 | 		change=$(last_shelved_change) && | 
 | 		git p4 unshelve $change && | 
 | 		git diff refs/remotes/p4-unshelved/$change.0 refs/remotes/p4-unshelved/$change | grep -q file3 | 
 | 	) | 
 | ' | 
 |  | 
 | shelve_one_file () { | 
 | 	description="Change to be unshelved" && | 
 | 	file="$1" && | 
 | 	p4 shelve -i <<EOF | 
 | Change: new | 
 | Description: | 
 | 	$description | 
 | Files: | 
 | 	$file | 
 | EOF | 
 | } | 
 |  | 
 | # This is the tricky case where the shelved changelist base revision doesn't | 
 | # match git-p4's idea of the base revision | 
 | # | 
 | # We will attempt to unshelve a change that is based on a change one commit | 
 | # ahead of p4/master | 
 |  | 
 | test_expect_success 'create shelved changelist based on p4 change ahead of p4/master' ' | 
 | 	git p4 clone --dest="$git" //depot/@all && | 
 | 	( | 
 | 		cd "$cli" && | 
 | 		p4 revert ... && | 
 | 		p4 edit file1 && | 
 | 		echo "foo" >>file1 && | 
 | 		p4 submit -d "change:foo" && | 
 | 		p4 edit file1 && | 
 | 		echo "bar" >>file1 && | 
 | 		shelve_one_file //depot/file1 && | 
 | 		change=$(last_shelved_change) && | 
 | 		p4 describe -S $change >out.txt && | 
 | 		grep -q "Change to be unshelved" out.txt | 
 | 	) | 
 | ' | 
 |  | 
 | # Now try to unshelve it. | 
 | test_expect_success 'try to unshelve the change' ' | 
 | 	test_when_finished cleanup_git && | 
 | 	( | 
 | 		change=$(last_shelved_change) && | 
 | 		cd "$git" && | 
 | 		git p4 unshelve $change >out.txt && | 
 | 		grep -q "unshelved changelist $change" out.txt | 
 | 	) | 
 | ' | 
 |  | 
 | # Specify the origin. Create 2 unrelated files, and check that | 
 | # we only get the one in HEAD~, not the one in HEAD. | 
 |  | 
 | test_expect_success 'unshelve specifying the origin' ' | 
 | 	( | 
 | 		cd "$cli" && | 
 | 		: >unrelated_file0 && | 
 | 		p4 add unrelated_file0 && | 
 | 		p4 submit -d "unrelated" && | 
 | 		: >unrelated_file1 && | 
 | 		p4 add unrelated_file1 && | 
 | 		p4 submit -d "unrelated" && | 
 | 		: >file_to_shelve && | 
 | 		p4 add file_to_shelve && | 
 | 		shelve_one_file //depot/file_to_shelve | 
 | 	) && | 
 | 	test_when_finished cleanup_git && | 
 | 	git p4 clone --dest="$git" //depot/@all && | 
 | 	( | 
 | 		cd "$git" && | 
 | 		change=$(last_shelved_change) && | 
 | 		git p4 unshelve --origin HEAD~ $change && | 
 | 		git checkout refs/remotes/p4-unshelved/$change && | 
 | 		test_path_is_file unrelated_file0 && | 
 | 		test_path_is_missing unrelated_file1 && | 
 | 		test_path_is_file file_to_shelve | 
 | 	) | 
 | ' | 
 |  | 
 | test_done |