git使用规范
Git 使用规范
Commit 规范
每一个 Git commit message 由 header 和 body 组成。
1 | <header> |
header
header 是必须的,格式如下:
1 | <type>(<scope>): <short summary> |
Commit Type
- build: 影响构建系统或者外部依赖的更改,例如修改
pom.xml
,Dockerfile
,docker-compose.yml
的更改 - ci: 影响到 CI 配置或脚本的更改,例如修改
gitlab-ci.yml
, Github Actions 的配置文件等 - docs: 只修改了文档的更改
- feat: 增加新功能的更改
- fix: 修复 bug 的更改
- perf: 提高了程序性能的更改
- refactor: 既没有修复 bug 也没有增加新功能的更改(比如重构代码)
- test: 增加或改正测试代码
- style: 不改变代码含义的修改(比如格式化代码)
- chore: 其他不改变
src
或测试代码的修改 - revert: 撤回之前的
commit
scope
commit 所属的范围,例如:
- user:用户
- char:单字
- word:词语
- pron:发音
- site:网站服务
- article:文章
- ……(根据实际模块情况的需要添加)
如果 commit 不属于以上范围或包括多个范围,则不用加 scope 。
body
body 是可选的,与 header 一样,需要使用动词原形。body 中可以书写比 header 中更详细的信息,比如:
- 为什么做了这个更改
- 受到了什么启发
- 与之前版本的区别
- 功能的详细说明
- ……
样例
1 | fix: address an issue where return value can be null |
Branch 规范
Branch 类型
所有的 branch
分为五种类型:
master
|main
分支:主分支,发布项目的每一个稳定版本develop
|dev
分支:开发分支,项目开发过程中的最新版本release
分支:预发布分支*,在正式发布前的测试版本,命名为release-YYYYMMDD-版本号
feature
分支:功能分支*,项目的每一个功能都需要有单独的一个feature分支,命名为feature-功能编号
hotfix
分支:热修复分支*,修复已发布版本中存在的bug,命名为hotfix-YYYYMMDD-bug关键字
issue
分支: issue分支*,针对开发分支或主分支或预发布分支中的issue,命名为issue-YYYYMMDD-issue编号
- 当然,在开发过程中,我们还会有一些临时性的分支*,比如
fix-xxx
、test-xxx
等等,这类分支需要及时删除。
带*的分支为临时性分支,一旦完成开发,他们就会被合并,随后删除。
Branch 使用流程
开发新功能
- 从需求文档中了解新功能的各项要求
- 从
develop
分支中创建新的功能分支,并命名为feature-功能编号
- 进行功能开发
- 进行测试与修复bug
- 使用
pull request
将本分支合并至develop
分支,随后删除本分支
功能再开发
极少数情况下,对于某个功能再次进行开发,此时创建的功能分支应该加上序号。
举例来说,对于功能 GN0101
来说:
开发次数 | 功能分支命名 |
---|---|
1 | feature-GN0101 |
2 | feature-GN0101-02 |
3 | feature-GN0101-03 |
…… | feature-GN0101-XX |
相信我们不会对同一个功能开发100次。
预发布版本
- 从最新的
develop
分支中创建预发布分支,并命名为release-YYYYMMDD-版本号
- 进行测试,并进行bug修复。(不允许开发新功能)
- 使用
pull request
将本分支合并至develop
分支。(保存修复bug的代码) - 使用
pull request
将本分支合并至master
分支。(正式发布该版本) - 删除该分支
修复 bug
开发过程中
直接在所在的 branch
中提交相应的 fix
版本上线后
- 创建 bug 对应的
hotfix
分支,命名为hotfix-YYYYMMDD-bug关键字
- 修复 bug ,并提交 fix 类型的 commit
- 使用
pull request
将本分支合并至master
分支。(修复正式环境) - 使用
pull request
将本分支合并至develop
分支。(保存修复bug的代码) - 删除该分支
Merge 规范
必须通过
拉取请求
(Pull Request
) 申请修改仓库中的代码:- 创建项目 Fork
- 修改代码
- 从 Fork 中创建拉取请求
- 代码审查(Review)
- 根据代码审查意见修改内容
- 完成合并
拉取请求应当尽量做到:
- 清晰描述请求的功能
- 关闭相关的议题(issue)
- 添加必要的测试代码
- 解决可能的冲突
在尝试合并发生冲突时,必须人工解决冲突,禁止
git push -f
或在不阅读冲突代码的情况下直接采用一方代码