233 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			233 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # Copyright (c) 2010 Thomas Rast
 | |
| #
 | |
| 
 | |
| test_description='Test the post-rewrite hook.'
 | |
| . ./test-lib.sh
 | |
| 
 | |
| test_expect_success 'setup' '
 | |
| 	test_commit A foo A &&
 | |
| 	test_commit B foo B &&
 | |
| 	test_commit C foo C &&
 | |
| 	test_commit D foo D &&
 | |
| 	git checkout A^0 &&
 | |
| 	test_commit E bar E &&
 | |
| 	test_commit F foo F &&
 | |
| 	git checkout master
 | |
| '
 | |
| 
 | |
| mkdir .git/hooks
 | |
| 
 | |
| cat >.git/hooks/post-rewrite <<EOF
 | |
| #!/bin/sh
 | |
| echo \$@ > "$TRASH_DIRECTORY"/post-rewrite.args
 | |
| cat > "$TRASH_DIRECTORY"/post-rewrite.data
 | |
| EOF
 | |
| chmod u+x .git/hooks/post-rewrite
 | |
| 
 | |
| clear_hook_input () {
 | |
| 	rm -f post-rewrite.args post-rewrite.data
 | |
| }
 | |
| 
 | |
| verify_hook_input () {
 | |
| 	test_cmp expected.args "$TRASH_DIRECTORY"/post-rewrite.args &&
 | |
| 	test_cmp expected.data "$TRASH_DIRECTORY"/post-rewrite.data
 | |
| }
 | |
| 
 | |
| test_expect_success 'git commit --amend' '
 | |
| 	clear_hook_input &&
 | |
| 	echo "D new message" > newmsg &&
 | |
| 	oldsha=$(git rev-parse HEAD^0) &&
 | |
| 	git commit -Fnewmsg --amend &&
 | |
| 	echo amend > expected.args &&
 | |
| 	echo $oldsha $(git rev-parse HEAD^0) > expected.data &&
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git commit --amend --no-post-rewrite' '
 | |
| 	clear_hook_input &&
 | |
| 	echo "D new message again" > newmsg &&
 | |
| 	git commit --no-post-rewrite -Fnewmsg --amend &&
 | |
| 	test ! -f post-rewrite.args &&
 | |
| 	test ! -f post-rewrite.data
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_must_fail git rebase --onto A B &&
 | |
| 	echo C > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD^)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase --skip' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_must_fail git rebase --onto A B &&
 | |
| 	test_must_fail git rebase --skip &&
 | |
| 	echo D > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase --skip the last one' '
 | |
| 	git reset --hard F &&
 | |
| 	clear_hook_input &&
 | |
| 	test_must_fail git rebase --onto D A &&
 | |
| 	git rebase --skip &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse E) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -m' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_must_fail git rebase -m --onto A B &&
 | |
| 	echo C > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD^)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -m --skip' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_must_fail git rebase --onto A B &&
 | |
| 	test_must_fail git rebase --skip &&
 | |
| 	echo D > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| . "$TEST_DIRECTORY"/lib-rebase.sh
 | |
| 
 | |
| set_fake_editor
 | |
| 
 | |
| # Helper to work around the lack of one-shot exporting for
 | |
| # test_must_fail (as it is a shell function)
 | |
| test_fail_interactive_rebase () {
 | |
| 	(
 | |
| 		FAKE_LINES="$1" &&
 | |
| 		shift &&
 | |
| 		export FAKE_LINES &&
 | |
| 		test_must_fail git rebase -i "$@"
 | |
| 	)
 | |
| }
 | |
| 
 | |
| test_expect_success 'git rebase -i (unchanged)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_fail_interactive_rebase "1 2" --onto A B &&
 | |
| 	echo C > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD^)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -i (skip)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_fail_interactive_rebase "2" --onto A B &&
 | |
| 	echo D > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -i (squash)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	test_fail_interactive_rebase "1 squash 2" --onto A B &&
 | |
| 	echo C > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -i (fixup without conflict)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	FAKE_LINES="1 fixup 2" git rebase -i B &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -i (double edit)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	FAKE_LINES="edit 1 edit 2" git rebase -i B &&
 | |
| 	git rebase --continue &&
 | |
| 	echo something > foo &&
 | |
| 	git add foo &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD^)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_expect_success 'git rebase -i (exec)' '
 | |
| 	git reset --hard D &&
 | |
| 	clear_hook_input &&
 | |
| 	FAKE_LINES="edit 1 exec_false 2" git rebase -i B &&
 | |
| 	echo something >bar &&
 | |
| 	git add bar &&
 | |
| 	# Fails because of exec false
 | |
| 	test_must_fail git rebase --continue &&
 | |
| 	git rebase --continue &&
 | |
| 	echo rebase >expected.args &&
 | |
| 	cat >expected.data <<-EOF &&
 | |
| 	$(git rev-parse C) $(git rev-parse HEAD^)
 | |
| 	$(git rev-parse D) $(git rev-parse HEAD)
 | |
| 	EOF
 | |
| 	verify_hook_input
 | |
| '
 | |
| 
 | |
| test_done
 | 
