Code

test that git status works with merge conflict in, .gitmodules
[git.git] / t / t7503-pre-commit-hook.sh
1 #!/bin/sh
3 test_description='pre-commit hook'
5 . ./test-lib.sh
7 test_expect_success 'with no hook' '
9         echo "foo" > file &&
10         git add file &&
11         git commit -m "first"
13 '
15 test_expect_success '--no-verify with no hook' '
17         echo "bar" > file &&
18         git add file &&
19         git commit --no-verify -m "bar"
21 '
23 # now install hook that always succeeds
24 HOOKDIR="$(git rev-parse --git-dir)/hooks"
25 HOOK="$HOOKDIR/pre-commit"
26 mkdir -p "$HOOKDIR"
27 cat > "$HOOK" <<EOF
28 #!/bin/sh
29 exit 0
30 EOF
31 chmod +x "$HOOK"
33 test_expect_success 'with succeeding hook' '
35         echo "more" >> file &&
36         git add file &&
37         git commit -m "more"
39 '
41 test_expect_success '--no-verify with succeeding hook' '
43         echo "even more" >> file &&
44         git add file &&
45         git commit --no-verify -m "even more"
47 '
49 # now a hook that fails
50 cat > "$HOOK" <<EOF
51 #!/bin/sh
52 exit 1
53 EOF
55 test_expect_success 'with failing hook' '
57         echo "another" >> file &&
58         git add file &&
59         test_must_fail git commit -m "another"
61 '
63 test_expect_success '--no-verify with failing hook' '
65         echo "stuff" >> file &&
66         git add file &&
67         git commit --no-verify -m "stuff"
69 '
71 chmod -x "$HOOK"
72 test_expect_success POSIXPERM 'with non-executable hook' '
74         echo "content" >> file &&
75         git add file &&
76         git commit -m "content"
78 '
80 test_expect_success POSIXPERM '--no-verify with non-executable hook' '
82         echo "more content" >> file &&
83         git add file &&
84         git commit --no-verify -m "more content"
86 '
88 test_done