https://github.com/lazaroalvesr/convencional_commit_messages.md
Repositório com diretrizes e hooks do Git para garantir mensagens de commit padronizadas seguindo o formato Conventional Commits. 🚀
https://github.com/lazaroalvesr/convencional_commit_messages.md
ci-cd commit commit-message commit-msg conventional-commits git-best-practices git-hooks github pre-receive-hooks versionamento
Last synced: 3 months ago
JSON representation
Repositório com diretrizes e hooks do Git para garantir mensagens de commit padronizadas seguindo o formato Conventional Commits. 🚀
- Host: GitHub
- URL: https://github.com/lazaroalvesr/convencional_commit_messages.md
- Owner: lazaroalvesr
- Created: 2025-03-14T17:52:53.000Z (3 months ago)
- Default Branch: master
- Last Pushed: 2025-03-14T18:02:01.000Z (3 months ago)
- Last Synced: 2025-03-14T18:45:13.627Z (3 months ago)
- Topics: ci-cd, commit, commit-message, commit-msg, conventional-commits, git-best-practices, git-hooks, github, pre-receive-hooks, versionamento
- Homepage:
- Size: 0 Bytes
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
### Types
* `feat` Commits, that adds or remove a new feature
* `fix` Commits, that fixes a bug
* `refactor` Commits, that rewrite/restructure your code, however does not change any API behaviour
* `perf` Commits are special `refactor` commits, that improve performance
* `style` Commits, that do not affect the meaning (white-space, formatting, missing semi-colons, etc)
* `test` Commits, that add missing tests or correcting existing tests
* `docs` Commits, that affect documentation only
* `build` Commits, that affect build components like build tool, ci pipeline, dependencies, project version, ...
* `ops` Commits, that affect operational components like infrastructure, deployment, backup, recovery, ...
* `chore` Miscellaneous commits e.g. modifying `.gitignore`### Scopes
The `scope` provides additional contextual information.
* Is an **optional** part of the format
* Allowed Scopes depends on the specific project
* Don't use issue identifiers as scopes### Breaking Changes Indicator
Breaking changes should be indicated by an `!` before the `:` in the subject line e.g. `feat(api)!: remove status endpoint`
* Is an **optional** part of the format### Description
The `description` contains a concise description of the change.
* Is a **mandatory** part of the format
* Use the imperative, present tense: "change" not "changed" nor "changes"
* Think of `This commit will...` or `This commit should...`
* Don't capitalize the first letter
* No dot (`.`) at the end### Body
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"
* This is the place to mention issue identifiers and their relations### Footer
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 CHANGES:` followed by space or two newlines. The rest of the commit message is then used for this.### Examples
* ```
feat: add email notifications on new direct messages
```
* ```
feat(shopping cart): add the amazing button
```
* ```
feat!: remove ticket list endpointrefers to JIRA-1337
BREAKING CHANGES: ticket enpoints no longer supports list all entites.
```
* ```
fix(api): handle empty message in request body
```
* ```
fix(api): fix wrong calculation of request body checksum
```
* ```
fix: add missing parameter to service callThe error occurred because of .
```
* ```
perf: decrease memory footprint for determine uniqe visitors by using HyperLogLog
```
* ```
build: update dependencies
```
* ```
build(release): `bump version to 1.0.0
```
* ```
refactor: implement fibonacci number calculation as recursion
```
* ```
style: remove empty line
```
## Git Hook Scripts to ensure commit message header format### commit-msg Hook (local)
* ensure `node` and `npx` command is installed on your local machine
* create following file in your local repository folder`.git-hooks/commit-msg`
```shell
#!/usr/bin/env sh
commit_message="$1"
# exit with a non zero exit code incase of an invalid commit message
# use git-conventional-commits, see https://github.com/qoomon/git-conventional-commits
npx git-conventional-commits commit-msg-hook "$commit_message"
# or verify $commit_message with your own tooling
# ...
```
* âš make `.git-hooks/commit-msg` executable (unix: `chmod +x '.git-hooks/commit-msg'`)
* set git hook directory to `.githooks` `git config core.hooksPath '.git-hooks'`
* commit `.git-hooks` directory if you want to share them with your team, they only need to call the git config command once after cloning the repository### pre-receive Hook (server side)
* create following file in your repository folder `.git/hooks/pre-receive`
```shell
#!/usr/bin/env bash# 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_description_regex='.{1,100}'
commit_msg_regex="^(${commit_msg_type_regex})(\(${commit_msg_scope_regex}\))?: (${commit_msg_description_regex})\$"
merge_msg_regex="^Merge branch '.+'\$"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`
fifor commit in $rev_span; do
commit_msg_header=$(git show -s --format=%s $commit)
if ! [[ "$commit_msg_header" =~ (${commit_msg_regex})|(${merge_msg_regex}) ]]; then
echo "$commit" >&2
echo "ERROR: Invalid commit message format" >&2
echo "$commit_msg_header" >&2
error="true"
fi
done
doneif [ -n "$error" ]; then
exit 1
fi
```
* âš make `.git/hooks/pre-receive` executable (unix: `chmod +x '.git/hooks/pre-receive'`)-----
## References
* 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* https://github.com/github/platform-samples/tree/master/pre-receive-hooks
* https://github.community/t5/GitHub-Enterprise-Best-Practices/Using-pre-receive-hooks-in-GitHub-Enterprise/ba-p/13863# Agradecimentos
Este projeto foi baseado em um repositório que eu clonei de [Horácio Muller](https://gist.github.com/horaciomuller/32bbb7d8fee9203afe148d73510e2035). Agradeço pela inspiração e pelos recursos fornecidos!