Check if commit subject is compliant with HAProxy guidelines
This action checks that the commit subject is compliant with the patch classifying rules of HAProxy contribution guidelines. Also it does minimal check for a meaningful message in the commit subject: no less than 20 characters and at least 3 words.
Examples
Good
BUG/MEDIUM: fix set-var parsing bug in config-parser
MINOR: Add path-rewrite annotation
BUILD/MINOR: Add path-rewrite annotation
Bad
bug: fix set-var parsing bug in config-parser
BUG/MEDIUM: fix set-var
BUG/MODERATE: fix set-var parsing bug in config-parser
None.
Usage
steps:
- name: check-commit
uses: docker://ghcr.io/haproxytech/commit-check:TAG
env:
API_TOKEN: ${{ secrets.GITHUB_TOKEN }}
Check-commit works only on pull_request
events by inspecting all commit messages in a Pull Request. It uses Github API pull requests API to fetch the commits so API_TOKEN env_variable is required.
Example configuration
If a configuration file (.check-commit.yml
) is not available in the running directory, a built-in failsafe configuration identical to the one below is used.
---
HelpText: "Please refer to https://github.com/haproxy/haproxy/blob/master/CONTRIBUTING#L632"
PatchScopes:
HAProxy Standard Scope:
- MINOR
- MEDIUM
- MAJOR
- CRITICAL
PatchTypes:
HAProxy Standard Patch:
Values:
- BUG
- BUILD
- CLEANUP
- DOC
- LICENSE
- OPTIM
- RELEASE
- REORG
- TEST
- REVERT
Scope: HAProxy Standard Scope
HAProxy Standard Feature Commit:
Values:
- MINOR
- MEDIUM
- MAJOR
- CRITICAL
TagOrder:
- PatchTypes:
- HAProxy Standard Patch
- HAProxy Standard Feature Commit
Optional parameters
The program accepts an optional parameter to specify the location (path) of the base of the git repository. This can be useful in certain cases where the checked-out repo is in a non-standard location within the CI environment, compared to the running path from which the check-commit binary is being invoked.
aspell
to check also spellcheck errors aspell was added. it can be configured with .aspell.yml
example
mode: subject
min_length: 3
ignore:
- go.mod
- go.sum
- '*test.go'
- 'gen/*'
allowed:
- aspell
- config
min_length
is minimal word size that is checked (default: 3)
mode
can be set as
subject
default
option
- only subject of commit message will be checked
commit
- whole commit message will be checked
all
- both commit message and all code committed
disabled