@ -4,15 +4,49 @@ test_description='commit-msg hook'
. ./test-lib.sh
. ./test-lib.sh
test_expect_success "with no hook" \
test_expect_success 'with no hook' '
"echo 'foo' > file &&
git add file &&
git commit -m 'first'"
test_expect_success "--no-verify with no hook" \
echo "foo" > file &&
"echo 'bar' > file &&
git add file &&
git add file &&
git commit -m "first"
git commit --no-verify -m 'bar'"
'
# set up fake editor for interactive editing
cat > fake-editor <<'EOF'
#!/bin/sh
cp FAKE_MSG "$1"
exit 0
EOF
chmod +x fake-editor
FAKE_EDITOR="$(pwd)/fake-editor"
export FAKE_EDITOR
test_expect_success 'with no hook (editor)' '
echo "more foo" >> file &&
git add file &&
echo "more foo" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit
'
test_expect_success '--no-verify with no hook' '
echo "bar" > file &&
git add file &&
git commit --no-verify -m "bar"
'
test_expect_success '--no-verify with no hook (editor)' '
echo "more bar" > file &&
git add file &&
echo "more bar" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit --no-verify
'
# now install hook that always succeeds
# now install hook that always succeeds
HOOKDIR="$(git rev-parse --git-dir)/hooks"
HOOKDIR="$(git rev-parse --git-dir)/hooks"
@ -24,15 +58,39 @@ exit 0
EOF
EOF
chmod +x "$HOOK"
chmod +x "$HOOK"
test_expect_success "with succeeding hook" \
test_expect_success 'with succeeding hook' '
"echo 'more' >> file &&
git add file &&
git commit -m 'more'"
test_expect_success "--no-verify with succeeding hook" \
echo "more" >> file &&
"echo 'even more' >> file &&
git add file &&
git add file &&
git commit -m "more"
git commit --no-verify -m 'even more'"
'
test_expect_success 'with succeeding hook (editor)' '
echo "more more" >> file &&
git add file &&
echo "more more" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit
'
test_expect_success '--no-verify with succeeding hook' '
echo "even more" >> file &&
git add file &&
git commit --no-verify -m "even more"
'
test_expect_success '--no-verify with succeeding hook (editor)' '
echo "even more more" >> file &&
git add file &&
echo "even more more" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit --no-verify
'
# now a hook that fails
# now a hook that fails
cat > "$HOOK" <<EOF
cat > "$HOOK" <<EOF
@ -40,26 +98,74 @@ cat > "$HOOK" <<EOF
exit 1
exit 1
EOF
EOF
test_expect_failure "with failing hook" \
test_expect_failure 'with failing hook' '
"echo 'another' >> file &&
git add file &&
echo "another" >> file &&
git commit -m 'another'"
git add file &&
git commit -m "another"
'
test_expect_failure 'with failing hook (editor)' '
echo "more another" >> file &&
git add file &&
echo "more another" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit
test_expect_success "--no-verify with failing hook" \
'
"echo 'stuff' >> file &&
git add file &&
test_expect_success '--no-verify with failing hook' '
git commit --no-verify -m 'stuff'"
echo "stuff" >> file &&
git add file &&
git commit --no-verify -m "stuff"
'
test_expect_success '--no-verify with failing hook (editor)' '
echo "more stuff" >> file &&
git add file &&
echo "more stuff" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit --no-verify
'
chmod -x "$HOOK"
chmod -x "$HOOK"
test_expect_success "with non-executable hook" \
test_expect_success 'with non-executable hook' '
"echo 'content' >> file &&
git add file &&
echo "content" >> file &&
git commit -m 'content'"
git add file &&
git commit -m "content"
'
test_expect_success 'with non-executable hook (editor)' '
echo "content again" >> file &&
git add file &&
echo "content again" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit -m "content again"
'
test_expect_success '--no-verify with non-executable hook' '
echo "more content" >> file &&
git add file &&
git commit --no-verify -m "more content"
'
test_expect_success "--no-verify with non-executable hook" \
test_expect_success '--no-verify with non-executable hook (editor)' '
"echo 'more content' >> file &&
git add file &&
echo "even more content" >> file &&
git commit --no-verify -m 'more content'"
git add file &&
echo "even more content" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit --no-verify
'
# now a hook that edits the commit message
# now a hook that edits the commit message
cat > "$HOOK" <<'EOF'
cat > "$HOOK" <<'EOF'
@ -73,16 +179,42 @@ commit_msg_is () {
test "`git log --pretty=format:%s%b -1`" = "$1"
test "`git log --pretty=format:%s%b -1`" = "$1"
}
}
test_expect_success "hook edits commit message" \
test_expect_success 'hook edits commit message' '
"echo 'additional' >> file &&
git add file &&
echo "additional" >> file &&
git commit -m 'additional' &&
git add file &&
commit_msg_is 'new message'"
git commit -m "additional" &&
commit_msg_is "new message"
test_expect_success "hook doesn't edit commit message" \
"echo 'plus' >> file &&
'
git add file &&
git commit --no-verify -m 'plus' &&
test_expect_success 'hook edits commit message (editor)' '
commit_msg_is 'plus'"
echo "additional content" >> file &&
git add file &&
echo "additional content" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit &&
commit_msg_is "new message"
'
test_expect_success "hook doesn't edit commit message" '
echo "plus" >> file &&
git add file &&
git commit --no-verify -m "plus" &&
commit_msg_is "plus"
'
test_expect_success "hook doesn't edit commit message (editor)" '
echo "more plus" >> file &&
git add file &&
echo "more plus" > FAKE_MSG &&
GIT_EDITOR="$FAKE_EDITOR" git commit --no-verify &&
commit_msg_is "more plus"
'
test_done
test_done