|  | #!/bin/sh | 
|  | # | 
|  | # Copyright (c) 2006 Josh England | 
|  | # | 
|  |  | 
|  | test_description='Test the post-merge hook.' | 
|  | . ./test-lib.sh | 
|  |  | 
|  | test_expect_success setup ' | 
|  | echo Data for commit0. >a && | 
|  | git update-index --add a && | 
|  | tree0=$(git write-tree) && | 
|  | commit0=$(echo setup | git commit-tree $tree0) && | 
|  | echo Changed data for commit1. >a && | 
|  | git update-index a && | 
|  | tree1=$(git write-tree) && | 
|  | commit1=$(echo modify | git commit-tree $tree1 -p $commit0) && | 
|  | git update-ref refs/heads/master $commit0 && | 
|  | git-clone ./. clone1 && | 
|  | GIT_DIR=clone1/.git git update-index --add a && | 
|  | git-clone ./. clone2 && | 
|  | GIT_DIR=clone2/.git git update-index --add a | 
|  | ' | 
|  |  | 
|  | for clone in 1 2; do | 
|  | cat >clone${clone}/.git/hooks/post-merge <<'EOF' | 
|  | #!/bin/sh | 
|  | echo $@ >> $GIT_DIR/post-merge.args | 
|  | EOF | 
|  | chmod u+x clone${clone}/.git/hooks/post-merge | 
|  | done | 
|  |  | 
|  | test_expect_success 'post-merge does not run for up-to-date ' ' | 
|  | GIT_DIR=clone1/.git git merge $commit0 && | 
|  | ! test -f clone1/.git/post-merge.args | 
|  | ' | 
|  |  | 
|  | test_expect_success 'post-merge runs as expected ' ' | 
|  | GIT_DIR=clone1/.git git merge $commit1 && | 
|  | test -e clone1/.git/post-merge.args | 
|  | ' | 
|  |  | 
|  | test_expect_success 'post-merge from normal merge receives the right argument ' ' | 
|  | grep 0 clone1/.git/post-merge.args | 
|  | ' | 
|  |  | 
|  | test_expect_success 'post-merge from squash merge runs as expected ' ' | 
|  | GIT_DIR=clone2/.git git merge --squash $commit1 && | 
|  | test -e clone2/.git/post-merge.args | 
|  | ' | 
|  |  | 
|  | test_expect_success 'post-merge from squash merge receives the right argument ' ' | 
|  | grep 1 clone2/.git/post-merge.args | 
|  | ' | 
|  |  | 
|  | test_done |