Git Commit 规范

本文是对前面系列文章的补充与完善。前面的介绍,利用了 husky 与 lint-staged 使得在提交之前做一些 ESLint 和 Prettier 的操作,今天来补充完 Commit Message 提交说明规范。

Git 是目前最先进的分布式版本控制系统,Git 每次提交代码时,都需要写 Commit Message(提交说明),否则不允许提交。

# 单行(亦可多行输入,输入一个双引号,按 Enter 键即可,最后补全一个双引号)
$ git commit -m "xxx"

# 多行输入,输入命令进入编辑模式
$ git commit

在团队多人协作中,一份清晰简明的 Commit Message 很重要,它可以让我们清楚了解本次代码提交的目的以及解决了具体什么问题。也可能让后续 Code Review、信息查找、版本回退都更加高效可靠。

目前,社区有多种 Commit Message 的写法规范。本文介绍 Angular 规范,这是目前使用最广的写法,比较合理和系统化,并且有配套的工具。

Commit Message 规范

每次提交,Header 是必需的,而 Body 和 Footer 可以省略。

不管哪一部分,任何一行都不得超过 72 个字符(或 100 个字符)。这是为了避免自动换行影响美观。

<Header>
<空行>
<Body>
<空行>
<Footer>
Header 部分

它包括 typescopesubject 三部分,其中 typesubject 是必须的,而 scope 是可选的。

<type>(<scope>): <subject>
  1. type 用于说明 commit 的类型,只允许使用下面几个标识:
  • feat 新功能
    A new feature
  • fix 修复 bug
    A bug fix
  • docs 仅包含文档的修改
    Documentation only changes
  • style 格式化变动,不影响代码逻辑。比如删除多余的空白,删除分号等
    Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
  • refactor 重构,既不是新增功能,也不是修改 bug 的代码变动
    A code change that neither fixes a bug nor adds a feature
  • perf 性能优化
    A code change that improves performance
  • test 增加测试
    Adding missing tests or correcting existing tests
  • build 构建工具或外部依赖包的修改,比如更新依赖包的版本等
    Changes that affect the build system or external dependencies (example scopes: gulp, broccoli, npm)
  • ci 持续集成的配置文件或脚本的修改
    Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)
  • chore 杂项,其他不修改源代码与测试代码的修改
    Other changes that don't modify src or test files
  • revert 撤销某次提交
    Reverts a previous commit

如果 typefeatfix,则该 commit 将肯定会出现在 Change Log 中。其他情况(docschorestylerefactortest)由你决定,要不要放入 Change Log 中,建议是不要。

  1. scope 用于说明 commit 影响的范围,比如数据层、控制层、视图层等。根据项目本身情况处理,如: views, components, utils, test...

  2. subject 是 commit 目的的简短描述,不超过 50 个字符。

  • 以动词开头,使用第一个人称现在时,比如 change,而不是 changed 或者 changes
  • 第一字母小写
  • 结尾不加句号(.
Body 部分

Body 部分是对本次 commit 的详细描述,可以分成多行。下面是一个范例:

More detailed explanatory text, if necessary.  Wrap it to 
about 72 characters or so. 

Further paragraphs come after blank lines.

- Bullet points are okay, too
- Use a hanging indent

注意两点:

  • 使用第一人称现在时,比如使用 change 而不是 changed 或者 changes。
  • 应该说明代码变动的动机,以及与之前行为的对比。
Footer 部分

Footer 部分只用于两种情况。

  1. 不兼容的变动

如果当前代码与上一个版本不兼容,则 Footer 部分以 BREAKING CHANGE 开头,后面是对变动的描述以及变动理由和迁移方法。

BREAKING CHANGE: isolate scope bindings definition has changed.

    To migrate the code follow the example below:

    Before:

    scope: {
      myAttr: 'attribute',
    }

    After:

    scope: {
      myAttr: '@',
    }

    The removed `inject` wasn't generaly useful for directives so there should be no code using it.
  1. 关闭 Issue

如果当前 commit 针对某个 issue,那么旧可以在 Footer 部分关闭这个 issue。

# 关闭单个
Closes #123

# 关闭多个
Closes #123, #234, #345
Revert

还有一种特殊情况,如果当前 commit 用于撤销以前的 commit,则必须以 revert: 开头,后面跟着被撤销 Commit 的 Header。

Body 部分格式是固定的,必须写成 This reverts commit <hash>.,其中的 hash 是被撤销 commit 的 SHA 标识符。

revert: feat(pencil): add 'graphiteWidth' option

This reverts commit 667ecc1654a317a13331b17617d973392f415f02.

如果当前 commit 与被撤销的 commit 在同一个发布(release)里面,那么它都不会出现在 Change Log 里面。如果两者在不同的发布,那么当前 commit,会出现在 Change Log 的 Reverts 小标题下面。

Commitizen

Commitizen 是一个撰写符合上面 Commit Message 标准的一款工具。

可以全局安装或者项目本地安装,我采用后者,但都会介绍一下。

全局安装

# 全局安装方法

# 下载
$ yarn global add commitizen cz-conventional-changelog

# 创建 .czrc 文件
$ vi ~/.czrc

# 写入如下内容并保存
{ "path": "cz-conventional-changelog" }

# 完了之后,可以使用 git cz 来代替 git commit 了。

项目局部安装

$ yarn add --dev commitizen cz-conventional-changelog

接着往 package.json 添加配置:

{
  "scripts": {
    "commit": "git-cz",
    "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md"
  },
  "config": {
    "commitizen": {
      "path": "./node_modules/cz-conventional-changelog"
    }
  }
}

commitizen 与 cz-conventional-changelog 的关系?

commitizen 根据不同的 Adapter 配置 Commit Message。比如,要使用 Angular 的 Commit Message 格式,可以安装 cz-conventional-changelog。还有很多其他的 Adapter...

实践

其中 scope、breaking changes、issue 等非必需项可回车跳过。


生成 Change Log

如果你的所有 Commit 都符合 Angular 格式,那么发布新版本时, Change Log 就可以用脚本自动生成。

生成的文档包括以下三个部分。

  • New features
  • Bug fixes
  • Breaking changes.

conventional-changelog 就是生成 Change Log 的工具,此前已安装并配置

{
  "scripts": {
    "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md"
  }
}

运行以下命令生成 CHANGELOG 文件,其中 featfix 类型的变动会生成在里面。

$ yarn run changelog

每个部分都会罗列相关的 commit ,并且有指向这些 commit 的链接。当然,生成的文档允许手动修改,所以发布前,你还可以添加其他内容。

文章的示例 Demo 在这里 GitHub: wechat_applet_demo,欢迎 Star 。

参考

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342