Merge branch 'bw/ref-prefix-for-configured-refspec'
[git/raj.git] / t / t5571-pre-push-hook.sh
blobac53d638695b69b67e18832846be8105864367de
1 #!/bin/sh
3 test_description='check pre-push hooks'
4 . ./test-lib.sh
6 # Setup hook that always succeeds
7 HOOKDIR="$(git rev-parse --git-dir)/hooks"
8 HOOK="$HOOKDIR/pre-push"
9 mkdir -p "$HOOKDIR"
10 write_script "$HOOK" <<EOF
11 cat >/dev/null
12 exit 0
13 EOF
15 test_expect_success 'setup' '
16 git config push.default upstream &&
17 git init --bare repo1 &&
18 git remote add parent1 repo1 &&
19 test_commit one &&
20 git push parent1 HEAD:foreign
22 write_script "$HOOK" <<EOF
23 cat >/dev/null
24 exit 1
25 EOF
27 COMMIT1="$(git rev-parse HEAD)"
28 export COMMIT1
30 test_expect_success 'push with failing hook' '
31 test_commit two &&
32 test_must_fail git push parent1 HEAD
35 test_expect_success '--no-verify bypasses hook' '
36 git push --no-verify parent1 HEAD
39 COMMIT2="$(git rev-parse HEAD)"
40 export COMMIT2
42 write_script "$HOOK" <<'EOF'
43 echo "$1" >actual
44 echo "$2" >>actual
45 cat >>actual
46 EOF
48 cat >expected <<EOF
49 parent1
50 repo1
51 refs/heads/master $COMMIT2 refs/heads/foreign $COMMIT1
52 EOF
54 test_expect_success 'push with hook' '
55 git push parent1 master:foreign &&
56 diff expected actual
59 test_expect_success 'add a branch' '
60 git checkout -b other parent1/foreign &&
61 test_commit three
64 COMMIT3="$(git rev-parse HEAD)"
65 export COMMIT3
67 cat >expected <<EOF
68 parent1
69 repo1
70 refs/heads/other $COMMIT3 refs/heads/foreign $COMMIT2
71 EOF
73 test_expect_success 'push to default' '
74 git push &&
75 diff expected actual
78 cat >expected <<EOF
79 parent1
80 repo1
81 refs/tags/one $COMMIT1 refs/tags/tag1 $ZERO_OID
82 HEAD~ $COMMIT2 refs/heads/prev $ZERO_OID
83 EOF
85 test_expect_success 'push non-branches' '
86 git push parent1 one:tag1 HEAD~:refs/heads/prev &&
87 diff expected actual
90 cat >expected <<EOF
91 parent1
92 repo1
93 (delete) $ZERO_OID refs/heads/prev $COMMIT2
94 EOF
96 test_expect_success 'push delete' '
97 git push parent1 :prev &&
98 diff expected actual
101 cat >expected <<EOF
102 repo1
103 repo1
104 HEAD $COMMIT3 refs/heads/other $ZERO_OID
107 test_expect_success 'push to URL' '
108 git push repo1 HEAD &&
109 diff expected actual
112 test_expect_success 'set up many-ref tests' '
114 nr=1000
115 while test $nr -lt 2000
117 nr=$(( $nr + 1 ))
118 echo "create refs/heads/b/$nr $COMMIT3"
119 done
120 } | git update-ref --stdin
123 test_expect_success 'sigpipe does not cause pre-push hook failure' '
124 echo "exit 0" | write_script "$HOOK" &&
125 git push parent1 "refs/heads/b/*:refs/heads/b/*"
128 test_done