JavaJVM · Java虚拟机原理 · JVM上语言·框架· 生态系统

美团 Git Commit Log规范

2020-12-15  本文已影响0人  木小丰_

一、背景

Git每次提交代码都需要写commit message,一般来说,commit message应该清晰明了,说明本次提交的目的,具体做了什么操作等。但是在日常开发中,开发者提交的的commit message千奇百怪,中英文混合使用,这就导致后续代码维护成本特别大,有时自己都不知道自己的fix bug修改的是什么问题。基于以上这些问题,我们希望通过某种方式来监控用户的git commit message,让规范更好的服务于质量,提高大家的研发效率。

二、约定

所有项目的Commit Log的格式精确控制,增加可读性,便于查看变更历史,形成良好的git使用习惯。规范作为git hook的commit-msg和pre-receive执行,不合法无法提交。全面执行后可自动化执行以下操作:

三、Commit Log Format

Commit Log包含三部分header、body、footer,其中header是必须的,格式固定,body在变更有必要详细解释时使用。

commit log 格式

Plain Text

<types>(<scopes>): <subject>
<空行>
<body>
<空行>
<footer>

注意:冒号后面必须有一个小写空格,types和scopes可为多个,中间用逗号分隔。

举例

  1. 仅header:
fix(service,dao): 修改产品类型时不过滤产品Type

  1. 仅header,涉及模块较多用*代替
refactor(*): 修改DTO模型前缀

  1. 有header和body
fix(language-service): Improve signature selection for pipes with args

Pipes with arguments like `slice:0` or `slice:0:1` should not produce
diagnostic errors.

  1. 有header、body、footer
func(core,logic): 添加礼包审核

添加商品编辑审核状态和回调,blablablabla

PRD:https://km.sankuai.com/page/194127085

1、Type

英文,小写。必须为下列中一个或多个:

2、Scope

英文,小写。表示变更的包或模块范围,可多个组合,若涉及范围较大,可用 * 代替。各服务可以自行定义,组内同学可轻易理解。通用scope列表如下:

除上述通用字段外,Scope中各方向可自行定义关键字。例如以下为商品平台中所定义字段:

3、Subject

中文。标题简述修改,结尾不要有句号。

4、Body

中文。修改的背景(为什么做这次修改),说明修改逻辑。

5、Footer

中文。可以放置需求wiki或task链接,对以后其他同学blame很有用。

四、规范校验

1、commit log正则表达式(持续集成工具会用到):

Java代码块

(^(\w+)\(([\w+,.\-_*]+?)\): .+(.|\n)*)|(^Automatic merge(.|\n)*)|(^Merge (.|\n)*)

2、本地卡控

#!/usr/bin/env python

import sys, os, re
from subprocess import check_output

commit_msg_filepath = sys.argv[1]
commit_type = sys.argv[2] if len(sys.argv) > 2 else ''
branch = check_output(['git', 'symbolic-ref', '--short', 'HEAD']).strip()

print "commit_type:", commit_type

with open(commit_msg_filepath, 'r+') as f:
    content = f.read()

    # ignore merge
    if content.startswith('Merge'):
        sys.exit(0)

    result = re.match('(\w+)\(([\w+,.\-_*]+?)\): .+(.|\n)*)', content)
    if result is None:
        print "ERROR: commit msg not match pattern '<type>(<scope>): <subject>'\n\t%s" % content
        sys.exit(1)

    sys.exit(0)

然后在git仓库一级目录下执行:

mv commit-msg.txt .git/hooks/commit-msg
chmod +x .git/hooks/commit-msg

五、声明

本文章授权公共号:肉眼品世界 首发

原文链接:https://lesofn.com/archives/mei-tuan-c-o-m-m-i-t--l-o-g-gui-fan

作者简介

美团Java高级工程师,关注软件架构及职业成长,不定期分享各种技术、资源,对文章中涉及的技术感兴趣或有任何问题请关注微信交流。

公共号:Java研发

上一篇下一篇

猜你喜欢

热点阅读