1.0.0 • Published 5 years ago
@quatredeux/commitlint-configuration v1.0.0
@quatredeux/commitlint-configuration
Shareable commitlint configuration enforcing Quatre Deux commit message convention
Getting started
# Installing via npm
npm i @quatredeux/commitlint-configuration --save-dev
# Installing via Yarn
yarn add @quatredeux/commitlint-configuration --dev
# Configures the convention
echo "module.exports = {extends: ['@quatredeux/commitlint-configuration']};" > commitlint.config.js
Rules
The following rules are considered problems and will yield a non-zero exit code when not met.
header-max-length
- condition:
header
hasvalue
or less characters - rule:
always
- level:
error
- value:
75
echo "feat: some message that is way too long and breaks the max-length rule by several characters" # fails
echo "feat: some message" # passes
type-enum
- condition:
type
is found invalue
- rule:
always
- level:
error
- value:
['build', 'doc', 'feat', 'fix', 'improv', 'perf', 'refac', 'revert', 'style', 'test']
echo "foo: some message" # fails
echo "feat: some message" # passes
type-empty
- condition:
type
is empty - rule:
never
- level:
error
echo ": some message" # fails
echo "feat: some message" # passes
type-case
- description:
type
is in casevalue
- rule:
always
- level:
error
- value:
'lower-case'
echo "FEAT: some message" # fails
echo "feat: some message" # passes
scope-case
- condition:
scope
is in casevalue
- rule:
always
- level:
error
- value:
'lower-case'
echo "feat(SCOPE): some message" # fails
echo "feat(scope): some message" # passes
subject-empty
- condition:
subject
is empty - rule:
never
- level:
error
echo "feat:" # fails
echo "feat: some message" # passes
subject-case
- condition:
subject
is one ofvalue
- rule:
never
- level:
error
- value:
['sentence-case', 'start-case', 'pascal-case', 'upper-case']
echo "feat(SCOPE): Some message" # fails
echo "feat(SCOPE): Some Message" # fails
echo "feat(SCOPE): SomeMessage" # fails
echo "feat(SCOPE): SOMEMESSAGE" # fails
echo "feat(scope): some message" # passes
echo "feat(scope): some Message" # passes
subject-full-stop
- condition:
subject
ends withvalue
- rule:
never
- level:
error
- value:
'.'
echo "feat: some message." # fails
echo "feat: some message" # passes
body-leading-blank
- condition:
body
must have a leading blank line - rule:
always
- level:
error
echo "feat: some message
body message" # fails
echo "feat: some message
body message" # passes
body-max-line-length
- condition:
body
each line hasvalue
or less characters - rule:
always
- level:
error
- value:
100
echo "feat: some message
body with multiple lines
has a message that is way too long and will definitely break the max-line-length rule by several characters" # fails
echo "feat: some message
body with multiple lines
but still no line is too long" # passes
body-max-length
- condition:
body
hasvalue
or less characters - rule:
always
- level:
error
- value:
500
footer-leading-blank
- condition:
footer
must have a leading blank line - rule:
always
- level:
error
echo "feat: some message
BREAKING CHANGE: It will break a lot" # fails
echo "feat: some message
BREAKING CHANGE: It will break a lot" # passes
footer-max-line-length
- condition:
footer
each line hasvalue
or less characters - rule:
always
- level:
error
- value:
100
echo "feat: some message
BREAKING CHANGE: footer with multiple lines
has a message that is way too long and will definitely break the max-line-length rule by several characters" # fails
echo "feat: some message
BREAKING CHANGE: footer with multiple lines
but still has a not too long message" # passes
footer-max-length
- condition:
footer
hasvalue
or less characters - rule:
always
- level:
error
- value:
200
License
Code released under the MIT License.
1.0.0
5 years ago