コミットメッセージのフォーマットをウツクシク保つには
注意:type
/scope
はアルファベットのみしか対応していないようです
コミット時のメッセージのフォーマットをそろえておくと、デバッグ/rollback時などに分かりやすいだけではなく、
コミット履歴からchangelogを自動生成するなどの運用も可能になります。
いちいちコミット文のフォーマットを確認するのは面倒くさいですが、
pre-commit hook
を使えば、コミットする前に自動でチェックしてくれるようになります。
今回は以下のようなフォーマットで統一することを目指しますが、設定をいじれば編集可能です。
<type>(<scope>): <subject>
test(staging): 〇〇の機能のテストを追加
huskyをインストール
npm install husky --save-dev
こうすると、コミット前に関連したnpm scriptが走るようになります。
validate-commit-msgをインストール
npm install --save-dev validate-commit-msg
インストールした後は、package.jsonで"commitmsg": validate-commit-msg
コマンドを追加します。
{
"scripts": {
"commitmsg": "validate-commit-msg"
}
}
コミットメッセージのフォーマットは、ここで設定できます。
詳しくは公式参照ですが、
types
やscope
の単語を変更したり、subjectPattern
に入れたい単語を指定することでわりと必要な情報がそろったコミットになると思います。
(ただ、こちらでtypes
を日本語にカスタマイズしてみたところ、認識されませんでした・・・)
{
"config": {
"validate-commit-msg": {
"types": ["feat", "fix", "docs", "style", "refactor", "perf", "test", "build", "ci", "chore", "revert"],
"scope": {
"required": false,
"allowed": ["*"],
"validate": false,
"multiple": false
},
"warnOnFail": false,
"maxSubjectLength": 100,
"subjectPattern": ".+",
"subjectPatternErrorMsg": "subject does not match subject pattern!",
"helpMessage": "",
"autoFix": false
}
}
}
ちなみに
husky
の機能を使えば、precommit以外でもprepushなどのタイミングでnpm scriptを実行することができます。
{
"scripts": {
"precommit": "npm test",
"prepush": "npm test",
"...": "..."
}
}
git-hook
との対応表はこちら。
https://github.com/typicode/husky/blob/master/HOOKS.md
Author And Source
この問題について(コミットメッセージのフォーマットをウツクシク保つには), 我々は、より多くの情報をここで見つけました https://qiita.com/nnishimura/items/dd5268dc59bf5c12ed07著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .