Lint your conventional commits, extended for use with changelogen
Shareable commitlint
config enforcing conventional commits.
Use with @commitlint/cli and @commitlint/prompt-cli.
Identical to @commitlint/config-conventional, with these changes:
- Added
examples
,types
for compatibility with changelogen - Updated commitizen icons to match changelogen
- Added a
wip
type for commits that should not hit the changelog
npm install --save-dev @commitlint-config-unjs @commitlint/cli
echo "module.exports = {extends: ['unjs']};" > commitlint.config.js
The following rules are considered problems for commitlint-config-unjs
and will yield a non-zero exit code when not met.
Consult docs/rules for a list of available rules.
-
condition:
type
is found in value -
rule:
always
-
level:
error
-
value
[ 'build', 'chore', 'ci', 'docs', 'examples', 'feat', 'fix', 'perf', 'refactor', 'revert', 'style', 'test', 'types', 'wip' ];
echo "foo: some message" # fails
echo "fix: some message" # passes
- description:
type
is in casevalue
- rule:
always
- level:
error
- value
'lowerCase'
echo "FIX: some message" # fails
echo "fix: some message" # passes
- condition:
type
is empty - rule:
never
- level:
error
echo ": some message" # fails
echo "fix: some message" # passes
- condition:
subject
is in one of the cases['sentence-case', 'start-case', 'pascal-case', 'upper-case']
- rule:
never
- level:
error
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
- condition:
subject
is empty - rule:
never
- level:
error
echo "fix:" # fails
echo "fix: some message" # passes
- condition:
subject
ends withvalue
- rule:
never
- level:
error
- value
'.'
echo "fix: some message." # fails
echo "fix: some message" # passes
- condition:
header
hasvalue
or less characters - rule:
always
- level:
error
- value
100
echo "fix: some message that is way too long and breaks the line max-length by several characters" # fails
echo "fix: some message" # passes
- condition:
footer
should have a leading blank line - rule:
always
- level:
warning
echo "fix: some message
BREAKING CHANGE: It will be significant" # warning
echo "fix: some message
BREAKING CHANGE: It will be significant" # passes
- condition:
footer
each line hasvalue
or less characters - rule:
always
- level:
error
- value
100
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
- condition:
body
should have a leading blank line - rule:
always
- level:
warning
echo "fix: some message
body" # warning
echo "fix: some message
body" # passes
- condition:
body
each line hasvalue
or less characters - rule:
always
- level:
error
- value
100
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