Shareable commitlint config enforcing senior conventional commits
npm install @seniorsistemas/commitlint-config-seniorLint your conventional commits
Shareable commitlint config enforcing conventional commits with custom rules for senior.
Use with @commitlint/cli and @commitlint/prompt-cli.
``sh`
npm install --save-dev @seniorsistemas/commitlint-config-senior @commitlint/cli
echo "export default {extends: ['@seniorsistemas/commitlint-config-senior']};" > commitlint.config.js
The following rules are considered problems for @seniorsistemas/commitlint-config-senior and will yield a non-zero exit code when not met.
Consult Rules reference for a list of available rules.
#### type-enum
- condition: type is found in valuealways
- rule: error
- level:
- 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 valuealways
- rule: error
- level: `
- value
`
'lowerCase'
`sh`
echo "FIX: some message" # fails
echo "fix: some message" # passes
#### type-empty
- condition: type is emptynever
- rule: error
- level:
`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']never
- rule: error
- level:
`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 emptynever
- rule: error
- level:
`sh`
echo "fix:" # fails
echo "fix: some message" # passes
#### subject-full-stop
- condition: subject ends with valuenever
- rule: error
- level:
- value
``
'.'
`sh`
echo "fix: some message." # fails
echo "fix: some message" # passes
#### header-max-length
- condition: header has value or less charactersalways
- rule: error
- level:
- 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 linealways
- rule: warning
- level:
`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 charactersalways
- rule: error
- level:
- 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 linealways
- rule: warning
- level:
`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 charactersalways
- rule: error
- level:
- 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
``