摘要:隨著團隊的變大,最近在開發(fā)過程中,越來越感覺到的重要性。注意年月日,阮一峰老師寫了一篇和編寫指南,本文主要來源于這篇文章,只是針對我們的團隊,進行了一些改造和簡化,以及對一些阮老師沒有提及的細小之處進行了指出。
隨著團隊的變大,最近在開發(fā)過程中,越來越感覺到commit log的重要性。之前的時候,團隊內(nèi)有人寫中文log,有人寫英文log;有人寫的還算清晰,有人一筆更新bug就概括全貌。這些良莠不齊的commit log充斥在我們的項目中,不僅影響了查閱的效果,還會對code review產(chǎn)生負面的影響。因此,本文是意圖從commit log的書寫規(guī)范入手,并提供相應(yīng)的解決方案。
注意:2016年1月6日,阮一峰老師寫了一篇《Commit message 和 Change log 編寫指南》,本文主要來源于這篇文章,只是針對我們的團隊,進行了一些改造和簡化,以及對一些阮老師沒有提及的細小之處進行了指出。
1. 書寫規(guī)范經(jīng)過一番調(diào)研,因為我們是小團隊,需要快速迭代,容易上手,所以對阮老師提到的commit log規(guī)范進行了簡化,具體如下:
1.1 type:
提交 commit 的類型,包括以下幾種
feat: 新功能
fix: 修復(fù)問題
docs: 修改文檔
style: 修改代碼格式,不影響代碼邏輯
refactor: 重構(gòu)代碼,理論上不影響現(xiàn)有功能
perf: 提升性能
test: 增加修改測試用例
revert: 回退,建議直接使用Github Desktop回退,而不是使用命令
1.2 subject用一句話清楚的描述這次提交做了什么。書寫要遵循以下四種規(guī)則:
格式盡量使用謂賓,使用謂賓不通順時,可以使用主謂,例如:
謂賓:修復(fù)xxxx
主謂:中間件支持xxxx
除了名稱之外,描述盡可能使用中文,方便不同開發(fā)者理解
結(jié)尾不加句號
描述控制在20個漢字以內(nèi)
1.3 body對本地提交的詳細描述,不建議。我們建議多次少量提交,而不是一次巨量的提交,有助于revert和code review,也對災(zāi)難存儲有容災(zāi)。
2. 撰寫工具有工具輔助,一定比手寫好,這里我們使用Commitizen這個庫。
安裝命令:
cd 項目目錄 npm install -g commitizen commitizen init cz-conventional-changelog --save --save-exact // 項目做些更改之后 git add . git cz
安裝完畢之后,使用git cz來代替git commit命令即可,新的commit log提交界面會如下所示:
寫完了之后的commit log如下圖所示:
是不是比之前的commit log看起來清晰很多?
注意:
git bash在windows下不能通過箭頭符號上下移動選擇,這時候我們可以下載Cmder來作為我們的命令行工具。
1. commit log 我用20個字描述不清楚怎么辦?
我們期望盡可能多次的提交,一個feature提交一次,不要出現(xiàn)積攢多個feature提交情況,既不有利于code review,也不有利于代碼revert
2. 為什么不使用強制驗證手段來限制commit log的格式?
盡管沒有使用自動化驗證的手段(阮老師的文章中提到了,可以自行查看),但是如果不符合書寫邏輯的話,code reviewer不應(yīng)該讓其merge request到dev分支中。這一塊我覺得天豬說的很有道理,通過人工的手段去實現(xiàn)這種驗證,這也是為了大家養(yǎng)成一個良好的代碼習慣。
《Commit message 和 Change log 編寫指南》
《代碼貢獻規(guī)范》
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52378.html
摘要:隨著團隊的變大,最近在開發(fā)過程中,越來越感覺到的重要性。注意年月日,阮一峰老師寫了一篇和編寫指南,本文主要來源于這篇文章,只是針對我們的團隊,進行了一些改造和簡化,以及對一些阮老師沒有提及的細小之處進行了指出。 隨著團隊的變大,最近在開發(fā)過程中,越來越感覺到commit log的重要性。之前的時候,團隊內(nèi)有人寫中文log,有人寫英文log;有人寫的還算清晰,有人一筆更新bug就概括全貌...
摘要:集成測試完成后,由運維同學從發(fā)起一個到分支,此時會會運行單元測試,構(gòu)建鏡像,并發(fā)布到預(yù)發(fā)布環(huán)境測試人員在預(yù)發(fā)布環(huán)境下再次驗證功能,團隊做上線前的其他準備工作運維同學合并,將為本次發(fā)布的代碼及鏡像自動打上版本號并書寫,同時發(fā)布到生產(chǎn)環(huán)境。 云原生 (Cloud Native) 是伴隨的容器技術(shù)發(fā)展出現(xiàn)的的一個詞,最早出自 Pivotal 公司(即開發(fā)了 Spring 的公司)的一本技術(shù)小...
摘要:集成測試完成后,由運維同學從發(fā)起一個到分支,此時會會運行單元測試,構(gòu)建鏡像,并發(fā)布到預(yù)發(fā)布環(huán)境測試人員在預(yù)發(fā)布環(huán)境下再次驗證功能,團隊做上線前的其他準備工作運維同學合并,將為本次發(fā)布的代碼及鏡像自動打上版本號并書寫,同時發(fā)布到生產(chǎn)環(huán)境。 云原生 (Cloud Native) 是伴隨的容器技術(shù)發(fā)展出現(xiàn)的的一個詞,最早出自 Pivotal 公司(即開發(fā)了 Spring 的公司)的一本技術(shù)小...
摘要:之后,在本地目錄生成代碼并且安裝項目依賴的包,最后將本次初始化生成的所有代碼自動提交到遠程倉庫。按照城市評選,分別評選明日之子僅限男性參加和閃亮女神僅限女性參加。 背景: 隨著開發(fā)團隊規(guī)模不斷發(fā)展壯大,在人員增加的同時也帶來了協(xié)作成本的增加,業(yè)務(wù)項目越來越多,類型也各不相同。常見的類型有組件類、活動類、基于React+redux的業(yè)務(wù)項目、RN項目、Node.js項目等等。如果想要對每...
閱讀 3029·2023-04-25 18:00
閱讀 2238·2021-11-23 10:07
閱讀 4082·2021-11-22 09:34
閱讀 1257·2021-10-08 10:05
閱讀 1579·2019-08-30 15:55
閱讀 3451·2019-08-30 11:21
閱讀 3352·2019-08-29 13:01
閱讀 1393·2019-08-26 18:26