You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
210 lines
3.9 KiB
210 lines
3.9 KiB
2 years ago
|
> Lint your conventional commits
|
||
|
|
||
|
# @commitlint/config-conventional
|
||
|
|
||
|
Shareable `commitlint` config enforcing [conventional commits](https://conventionalcommits.org/).
|
||
|
Use with [@commitlint/cli](https://npm.im/@commitlint/cli) and [@commitlint/prompt-cli](https://npm.im/@commitlint/prompt-cli).
|
||
|
|
||
|
## Getting started
|
||
|
|
||
|
```sh
|
||
|
npm install --save-dev @commitlint/config-conventional @commitlint/cli
|
||
|
echo "module.exports = {extends: ['@commitlint/config-conventional']};" > commitlint.config.js
|
||
|
```
|
||
|
|
||
|
## Rules
|
||
|
|
||
|
### Problems
|
||
|
|
||
|
The following rules are considered problems for `@commitlint/config-conventional` and will yield a non-zero exit code when not met.
|
||
|
|
||
|
Consult [docs/rules](https://conventional-changelog.github.io/commitlint/#/reference-rules) for a list of available rules.
|
||
|
|
||
|
#### type-enum
|
||
|
|
||
|
- **condition**: `type` is found in value
|
||
|
- **rule**: `always`
|
||
|
- **level**: `error`
|
||
|
- **value**
|
||
|
|
||
|
```
|
||
|
[
|
||
|
'build',
|
||
|
'chore',
|
||
|
'ci',
|
||
|
'docs',
|
||
|
'feat',
|
||
|
'fix',
|
||
|
'perf',
|
||
|
'refactor',
|
||
|
'revert',
|
||
|
'style',
|
||
|
'test'
|
||
|
];
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "foo: some message" # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### type-case
|
||
|
|
||
|
- **description**: `type` is in case `value`
|
||
|
- **rule**: `always`
|
||
|
- **level**: `error`
|
||
|
- **value**
|
||
|
```
|
||
|
'lowerCase'
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "FIX: some message" # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### type-empty
|
||
|
|
||
|
- **condition**: `type` is empty
|
||
|
- **rule**: `never`
|
||
|
- **level**: `error`
|
||
|
|
||
|
```sh
|
||
|
echo ": some message" # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### subject-case
|
||
|
|
||
|
- **condition**: `subject` is in one of the cases `['sentence-case', 'start-case', 'pascal-case', 'upper-case']`
|
||
|
- **rule**: `never`
|
||
|
- **level**: `error`
|
||
|
|
||
|
```sh
|
||
|
echo "fix(SCOPE): Some message" # fails
|
||
|
echo "fix(SCOPE): Some Message" # fails
|
||
|
echo "fix(SCOPE): SomeMessage" # fails
|
||
|
echo "fix(SCOPE): SOMEMESSAGE" # fails
|
||
|
echo "fix(scope): some message" # passes
|
||
|
echo "fix(scope): some Message" # passes
|
||
|
```
|
||
|
|
||
|
#### subject-empty
|
||
|
|
||
|
- **condition**: `subject` is empty
|
||
|
- **rule**: `never`
|
||
|
- **level**: `error`
|
||
|
|
||
|
```sh
|
||
|
echo "fix:" # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### subject-full-stop
|
||
|
|
||
|
- **condition**: `subject` ends with `value`
|
||
|
- **rule**: `never`
|
||
|
- **level**: `error`
|
||
|
- **value**
|
||
|
|
||
|
```
|
||
|
'.'
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message." # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### header-max-length
|
||
|
|
||
|
- **condition**: `header` has `value` or less characters
|
||
|
- **rule**: `always`
|
||
|
- **level**: `error`
|
||
|
- **value**
|
||
|
|
||
|
```
|
||
|
100
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message that is way too long and breaks the line max-length by several characters" # fails
|
||
|
echo "fix: some message" # passes
|
||
|
```
|
||
|
|
||
|
#### footer-leading-blank
|
||
|
|
||
|
- **condition**: `footer` should have a leading blank line
|
||
|
- **rule**: `always`
|
||
|
- level: `warning`
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message
|
||
|
BREAKING CHANGE: It will be significant" # warning
|
||
|
|
||
|
echo "fix: some message
|
||
|
|
||
|
BREAKING CHANGE: It will be significant" # passes
|
||
|
```
|
||
|
|
||
|
#### footer-max-line-length
|
||
|
|
||
|
- **condition**: `footer` each line has `value` or less characters
|
||
|
- **rule**: `always`
|
||
|
- level: `error`
|
||
|
- **value**
|
||
|
|
||
|
```
|
||
|
100
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message
|
||
|
|
||
|
BREAKING CHANGE: footer with multiple lines
|
||
|
has a message that is way too long and will break the line rule 'line-max-length' by several characters" # fails
|
||
|
|
||
|
echo "fix: some message
|
||
|
|
||
|
BREAKING CHANGE: footer with multiple lines
|
||
|
but still no line is too long" # passes
|
||
|
```
|
||
|
|
||
|
#### body-leading-blank
|
||
|
|
||
|
- **condition**: `body` should have a leading blank line
|
||
|
- **rule**: `always`
|
||
|
- level: `warning`
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message
|
||
|
body" # warning
|
||
|
|
||
|
echo "fix: some message
|
||
|
|
||
|
body" # passes
|
||
|
```
|
||
|
|
||
|
#### body-max-line-length
|
||
|
|
||
|
- **condition**: `body` each line has `value` or less characters
|
||
|
- **rule**: `always`
|
||
|
- level: `error`
|
||
|
- **value**
|
||
|
|
||
|
```
|
||
|
100
|
||
|
```
|
||
|
|
||
|
```sh
|
||
|
echo "fix: some message
|
||
|
|
||
|
body with multiple lines
|
||
|
has a message that is way too long and will break the line rule 'line-max-length' by several characters" # fails
|
||
|
|
||
|
echo "fix: some message
|
||
|
|
||
|
body with multiple lines
|
||
|
but still no line is too long" # passes
|
||
|
```
|