Lint your conventional commits
@millionfor/commitlint-conventional
Shareable commitlint
config enforcing conventional commits.
Use with @commitlint/cli and @commitlint/prompt-cli.
Getting started
yarn add -D @millionfor/commitlint-conventional @commitlint/cli
echo "module.exports = {extends: ['@millionfor/commitlint-conventional']};" > .commitlintrc.js
Rules
Problems
The following rules are considered problems for @millionfor/commitlint-conventional
and will yield a non-zero exit code when not met.
Consult docs/rules for a list of available rules.
type-enum
-
condition:
type
is found in value -
rule:
always
-
value
[ 'ci', 'chore', 'docs', 'feat', 'fix', 'improvement', 'perf', 'refactor', 'revert', 'style', 'test', 'ui' ]
echo "foo: some message" # fails
echo "fix: some message" # passes
- ci: Changes to our CI configuration files and scripts (example scopes: Circle, BrowserStack, SauceLabs)
- chore: Updating grunt tasks etc; no production code change
- docs: Documentation only changes
- feat: A new feature
- fix: A bug fix
- improvement: An improvement to a current feature
- perf: A code change that improves performance
- refactor: A code change that neither fixes a bug nor adds a feature
- style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
- test: Adding missing tests or correcting existing tests
- ui: Common ui adjustments (example: Button, Layout, etc,.)
type-case
-
description:
type
is in casevalue
-
rule:
always
-
value
'lowerCase'
echo "FIX: some message" # fails
echo "fix: some message" # passes
type-empty
-
condition:
type
is empty -
rule:
never
echo ": some message" # fails
echo "fix: some message" # passes
scope-case
-
condition:
scope
is in casevalue
-
rule:
always
'lowerCase'
echo "fix(SCOPE): some message" # fails
echo "fix(scope): some message" # passes
subject-case
-
condition:
subject
is in one of the cases['sentence-case', 'start-case', 'pascal-case', 'upper-case']
-
rule:
never
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
echo "fix:" # fails
echo "fix: some message" # passes
subject-full-stop
-
condition:
subject
ends withvalue
-
rule:
never
- value
'.'
echo "fix: some message." # fails
echo "fix: some message" # passes
header-max-length
-
condition:
header
hasvalue
or less characters -
rule:
always
- value
72
echo "fix: some message that is way too long and breaks the line max-length by several characters" # fails
echo "fix: some message" # passes
License
MIT Copyright (c) Allex Wang