See how a minor change to your commit message style can make a difference. Examples
<type>(<optional scope>): <subject> empty separator line <optional body> empty separator line <optional footer>
Merge branch '<branch name>'
Follows default git merge message
Revert "<commit headline>" empty separator line This reverts commit <commit hash>. <optinal reason>
Follows default git revert message
featA code change that adds a new featurefixA code change that adds a bug fixrefactorA code change that neither adds a new feature nor fixes a bugstyleA code change that do not affect the meaning (white-space, formatting, missing semi-colons, etc)testChanges that add missing tests or correcting existing testsdocsChanges that affect documentation onlybuildChanges that affect the build system or external dependenciesopsChanges that affect operational components like infrastructure, backup or recovery
The scope provides additional contextual information.
- Is an optional part of the format
- Allowed Scopes depends on the specific project
The subject contains a succinct description of the change.
- Is a mandatory part of the format
- Use the imperative, present tense: "change" not "changed" nor "changes"
- Don't capitalize the first letter
- No dot (.) at the end
The body should include the motivation for the change and contrast this with previous behavior.
- Is an optional part of the format
- Use the imperative, present tense: "change" not "changed" nor "changes"
The footer should contain any information about Breaking Changes and is also the place to reference Issues that this commit refers to.
- Is an optional part of the format
- optionally reference an issue by its id.
- Breaking Changes should start with the word
BREAKING CHANGE:folowed by space or two newlines. The rest of the commit message is then used for this.
-
feat(shopping cart): add the amazing button -
feat: remove ticket list endpoint refers to JIRA-1337 BREAKING CHANGE: ticket enpoints no longer supports list all entites. -
fix: add missing parameter to service call The error occurred because of <reasons>. -
build: release version 1.0.0 -
build: update dependencies -
refactor: implement calculation method as recursion -
style: remove empty line -
revert: refactor: implement calculation method as recursion This reverts commit 221d3ec6ffeead67cee8c730c4a15cf8dc84897a.
- set commit hook directory
git config core.hooksPath ".git-hooks" - create following file
.git-hooks/hooks/commit-msg
#!/usr/bin/env sh
# commit-msg hook that will ensure commit messge format
commit_msg_type_regex='feat|fix|refactor|style|test|docs|build'
commit_msg_scope_regex='.{1,20}'
commit_msg_subject_regex='.{1,100}'
commit_msg_regex="^(${commit_msg_type_regex})(\(${commit_msg_scope_regex}\))?: (${commit_msg_subject_regex})\$"
merge_msg_regex="^Merge branch '.+'\$"
revert_msg_regex="^Revert \".+\"\$"
commit_msg_header=$(head -1 $1)
if ! [[ "$commit_msg_header" =~ (${commit_msg_regex})|(${merge_msg_regex})|(${revert_msg_regex}) ]]; then
echo "ERROR: Invalid commit message format" >&2
echo "\n$commit_msg_header" >&2
exit 1
fi.git/hooks/pre-receive
#!/usr/bin/env sh
# Pre-receive hook that will block commits with messges that do not follow regex rule
commit_msg_type_regex='feat|fix|refactor|style|test|docs|build'
commit_msg_scope_regex='.{1,20}'
commit_msg_subject_regex='.{1,100}'
commit_msg_regex="^(${commit_msg_type_regex})(\(${commit_msg_scope_regex}\))?: (${commit_msg_subject_regex})\$"
merge_msg_regex="^Merge branch '.+'\$"
revert_msg_regex="^Revert \".+\"\$"
zero_commit="0000000000000000000000000000000000000000"
# Do not traverse over commits that are already in the repository
excludeExisting="--not --all"
error=""
while read oldrev newrev refname; do
# branch or tag get deleted
if [ "$newrev" = "$zero_commit" ]; then
continue
fi
# Check for new branch or tag
if [ "$oldrev" = "$zero_commit" ]; then
rev_span=`git rev-list $newrev $excludeExisting`
else
rev_span=`git rev-list $oldrev..$newrev $excludeExisting`
fi
for commit in $rev_span; do
commit_msg_header=$(git show -s --format=%s $commit)
if ! [[ "$commit_msg_header" =~ (${commit_msg_regex})|(${merge_msg_regex})|(${revert_msg_regex}) ]]; then
echo "$commit" >&2
echo "ERROR: Invalid commit message format" >&2
echo "$commit_msg_header" >&2
error="true"
fi
done
done
if [ -n "$error" ]; then
exit 1
fi
- https://www.conventionalcommits.org/
- https://github.com/angular/angular/blob/master/CONTRIBUTING.md
- http://karma-runner.github.io/1.0/dev/git-commit-msg.html