zoukankan      html  css  js  c++  java
  • 你还没用过“约定式提交”吗?那你赶紧来补补知识吧

    前言

    本文为介绍约定式提交,主要从以下几点展开:

    本文对应的github项目地址:https://github.com/larscheng/Conventional-Commits-Demo

    现状分析

    目前我们的项目在commit时基本上五花八门,各领风骚。虽然不如网上的那些恶搞commit记录,但是这一现象严重影响我们在阅读记录和查找bug原因时的效率。

    我们可以感受下:

    真实项目commit记录

    可以对比看看同样按照规范式提交的项目的commit记录

    两种commit message的对比很明显说明了情况,统一的提交信息,不仅看起来舒服,而且读起来更舒服

    其实已经越来越多的人开始意识到规范化提交的重要性,据我在公司实地采访了一圈,前端团队早已经开始约定式提交,这也可能是因为目前社区中主流的提交规范都是由Angular提交准则形成。

    为了提高开发效率,减少在处理问题时耗费的时间,推荐大家在写完代码,提交时能够使用以下规范:

    • 规范化提交(不一定是文中提到的方式,但无论哪种方式,要做到统一简明)
    • 一处变更一次commit(谨防多处、多次修改堆积成一次commit提交,这对后期bug分析将是灾难)

    约定式提交

    约定式提交:每次使用git commit 的时候都需要写commit message,如果message的 style是按照固定的模版格式书写,对于后期的维护和编写changelog都有巨大的好处。

    而且现在的很多自动生成changelog的工具,都是建立在约定式提交的基础之上。

    优点

    • 可读性好,清晰,不必深入看代码即可了解当前commit的作用。
    • 为 Code Reviewing做准备
    • 方便跟踪工程历史
    • 让其他的开发者在运行 git blame 的时候想跪谢
    • 提高项目的整体质量,提高个人工程素质

    约定式提交规范

    约定式提交规范是基于Angular提交准则形成,提交说明的结构如下:

    <类型>([可选的作用域]): <描述>
    // 空一行
    [可选的正文]
    // 空一行
    [可选的脚注]
    

    其中,<类型>是为了向类库使用者表明其意图,其可选值为:

    • feat: 表示新增了一个功能
    • fix: 表示修复了一个 bug
    • docs: 表示只修改了文档
    • style: 表示修改格式、书写错误、空格等不影响代码逻辑的操作
    • refactor: 表示修改的代码不是新增功能也不是修改 bug,比如代码重构
    • perf: 表示修改了提升性能的代码
    • test: 表示修改了测试代码
    • build: 表示修改了编译配置文件
    • chore: 无 src 或 test 的操作
    • revert: 回滚操作

    [可选的作用域]: 是为了描述 此次 commit 影响的范围,比如: route, component, utils, build, api, website, docs

    <描述>: 此次提交的简短描述

    [可选的正文]: 此次提交的详细描述,描述为什么修改,做了什么样的修改,以及开发的思路等等,输入 换行

    [可选的页脚]: 主要写下面2种

    • Breaking changes: 在可选的正文或脚注的起始位置带有 BREAKING CHANGE: 的提交,表示引入了破坏性变更(这和语义化版本中的 MAJOR 相对应)。
    • Closed issues: 罗列此次提交修复的 bug,如 fixes issue #110

    Commitizen

    Commitizen是一个撰写合格 Commit message 的工具。

    安装

    安装命令如下:任选其一

    $ npm install -g commitizen       (全局安装)
    $ npm install -d commitizen       (项目安装)
    

    然后,在项目目录里,运行下面的命令,使其支持 Angular 的 Commit message 格式。

    $ commitizen init cz-conventional-changelog --save --save-exact
    

    ps: 对于非Node项目(java、php...)在执行上一条命令前,需要手动创建package.json文件

    $ npm init --yes
    

    通过如上命令生成package.json文件基本格式如下:

    {
      "name": "demo",
      "version": "0.0.0",
      "private": true,
      "scripts": {
        "start": "node ./bin/www"
      }
    }
    

    以后,凡是用到git commit命令,一律改为使用git cz。这时,就会出现选项,用来生成符合格式的 Commit message。如图:

    git-cz

    standard-version

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

    standard-version就是生成 Change log 的工具

    安装使用

    安装命令如下:任选其一

    $ npm i -g standard-version       (全局安装)
    $ npm i -S standard-version       (项目安装)
    

    生成CHANGELOG:

    package.json中的script中 加入配置:

    "scirpt":{"release":"standard-version"}

    直接执行,即可生成CHANGELOG文件

    $ npm run release
    

    备注:

    生成CHANGELOG的工具很多,conventional-changelog-cli也可以用来生成CHANGELOG,安装使用方法和standard-version类似

    本项目的CHANGELOG生成实例:CHANGELOG查看



  • 相关阅读:
    java-抽象类
    java-接口
    java-面向对象总结
    java-单例设计模式
    java数组
    .Net框架整理
    PHP结合memcacheq消息队列解决并发问题
    浅谈DDos攻击
    PHP+ffmpeg+nginx的配置实现视频转码(转)
    使用Nginx的X-Accel-Redirect实现大文件下载
  • 原文地址:https://www.cnblogs.com/larscheng/p/11839745.html
Copyright © 2011-2022 走看看