git 只commit不push 会有影响吗_规范化团队 git 提交信息
規范化團隊 git 提交信息
同一個工程項目,為了方便管理,git 的 commit 信息最好按照一定的格式規范,以便在需要的時候方便使用。什么是方便的時候,比如出現了一個線上 bug,所以需要回滾操作,知道了提交信息可以方便的定位問題。代碼 review 的時候也知道了該次 commit 干了什么,所以 commit 標準化好處很多,不再舉例。實現
可以馬上想到的是利用 shell 結合 git hook 實現在 git commit 階段檢查輸入是否符合規范。符合就通過,不符合就終止,并給出提示信息。
規范是什么
常見的分類有下面幾種:
- build:修改項目的的構建系統(xcodebuild、webpack、glup等)的提交
- ci:修改項目的持續集成流程(Kenkins、Travis等)的提交
- chore:構建過程或輔助工具的變化
- docs:文檔提交(documents)
- feat:新增功能(feature)
- fix:修復 bug
- pref:性能、體驗相關的提交
- refactor:代碼重構
- revert:回滾某個更早的提交
- style:不影響程序邏輯的代碼修改、主要是樣式方面的優化、修改
- test:測試相關的開發
輪子
在 github 上有 commitlint 這個項目,它可以很方便的在工程中做配置,并允許你自定義上面說的「規范」、「分類」。
commitlint:用于檢查提交信息 husky:hook 工具,用于 git-commit 和 git-push 階段。
怎么用?
5. 在 package.json 文件中添加以下代碼,代碼層級跟 **devDependencies** 同級。
"husky": {"hooks": {"pre-commit": "echo '哈嘍,小伙伴們,在這里可以做測試相關的邏輯哦,一般結合公司的 ci'","commit-msg": "commitlint -E HUSKY_GIT_PARAMS","pre-push": "echo 提交代碼前需要先進行單元測試 && 可以做測試相關"}}上面的流程配置完成,當你在提交 commit 信息的輸入的內容,如果不符合 <type>: <subject> 規則,會終止并給出提示信息。
type 就是上面的種類;subject 就是需要提交的文字概括。比如:feature:增加搖一搖推薦酒店功能。
小說明:如果某次提交想禁用 husky,可以添加參數 --no-verify。git commit --no-verify -m "xxx"
貼個效果圖
commitlint流程說明
安裝包 husky 的時候,會在目錄 .git/hooks/ 下生成一堆 shell 腳本,負責 git 的 hook。
"commit-msg": "commitlint -E HUSKY_GIT_PARAMS" 這個配置告訴 git hooks,當執行 git commit -m 的時候觸發 commit-msg 鉤子,并通知 husky,從而執行 commitlint -E HUSKY_GIT_PARAMS,實際上執行的是 ./node_modules/husky/bin/run.js,讀取 commitlint.config.js 里的配置,然后對我們 commit -m 里的字符串校驗,如不通過則輸出錯誤信息并終止。
拓展篇
git commit 的幾個鉤子,也暴露出來了,所以可以結合時機做一些額外的邏輯。
- pre-commit:在 git commit 之前觸發
- commit-msg:在編寫 commit 信息的時候觸發
- pre-push:在 git push 之前觸發
所以基于上述時機,可以根據項目特點做一些別的事情。比如 code lint、unit test 代碼覆蓋率檢測、changelog 自動生成、unit test 腳本等、也可以借此機會產生 lint 報表
總結
以上是生活随笔為你收集整理的git 只commit不push 会有影响吗_规范化团队 git 提交信息的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: js打印线程id_一文讲透“进程,线程和
- 下一篇: 工作日报模板_千份财会人通用工作模板:自