@ranger-theme/branchlint-config
v0.1.0
Published
## ๐ Introduce
Readme
@ranger-theme/branchlint-config
๐ Introduce
git commit message ่ง่
๐ Documentation
๐ฆ Install
$ npm install --save-dev @ranger-theme/branchlint-config
# or
$ yarn add --save-dev @ranger-theme/branchlint-config
# or
$ pnpm add --save-dev @ranger-theme/branchlint-config๐จ Usage
{
"pre-push": "branch-name-lint"
}Alternatevly you can use it with husky.
Configuration
Config schema
interface Config {
pattern: string
params: Record<string, string[]>
prohibited: string[]
whiteList: string[]
}User provided configuration
Under the hood BranchNameLint uses cosmicconfig to load its configuration.
You can create one of the following:
branchnamelintproperty in thepackage.jsonfile- Extensionless "rc file" in
.jsonor.yamlformat.branchnamelintrc
- "rc file" with
.jsonor.yamlextensions.branchnamelintrc.json.branchnamelintrc.yaml
- "rc file" with
.jsextension.branchnamelintrc.js
- ".config.js" file
branchnamelint.config.js
don't forget to do
module.exports = {...}in.jsconfig files
BranchNameLint will merge found configuration with its defaults.
Default configuration
module.exports = {
pattern: ':type/:name',
params: {
type: ['fix', 'docs', 'misc', 'improve', 'introduce'],
name: ['[a-z0-9-]+']
},
prohibited: ['ci', 'wip', 'main', 'test', 'build', 'master', 'release'],
whiteList: ['staging']
}Linting
BranchNameLint uses path-to-regexp
to check if branch name matches the pattern provided in config.
The whiteList option will allow push code the this branch no any lint. Firstly branch name will be checked if its prohibited or not. On the next step,
if params are provided, pattern parts will be modified/populated using
respective keys. For example:
(default configuration)
:type/:name => :type(feature|fix|misc|docs)/:name([a-z0-9-]+)Please refer to path-to-regexp docs for advanced patterns.
Configuration recipes
Only check for protected branches
module.exports = {
pattern: '', // or other falsy value: undefined | 0 | null | false
params: {},
prohibited: ['master', 'main', 'build', 'test', 'wip', 'ci', 'release'],
whiteList: ['staging']
}module.exports = {
pattern: ':username.:type/:desc/:issue',
params: {
type: ['feature', 'fix', 'misc', 'docs'],
issue: ['lbn-[a-z0-9-]+']
},
prohibited: ['master', 'main', 'build', 'test', 'wip', 'ci', 'release'],
whiteList: ['staging']
}Scopes for monorepo
feature/my-awesome-app/yet-another-great-feature
(imaginary monorepo structure)
root/
apps/
my-awesome-app
another-great-app
libs/
very-useful-lib
shared-lib
.branchnamelintrc.jsconst fs = require('fs')
const readDirectories = (path) =>
fs
.readdirSync(path, { withFileTypes: true })
.filter((file) => file.isDirectory())
.map(({ name }) => name)
module.exports = {
pattern: ':type/:scope/:description',
params: {
type: ['feature', 'fix', 'misc', 'docs'],
scope: readDirectories('./apps')
},
prohibited: ['master', 'main', 'build', 'test', 'wip', 'ci', 'release'],
whiteList: ['staging']
}