Git Hooks简介及结合Husky和Commitlint检测提交代码规范

news2025/1/15 20:06:35

文章目录

    • 一、Git Hooks
      • 1.1 目标
      • 1.2 常用hooks
      • 1.3 核心钩子
    • 二、Commitlint
      • 2.1 安装
      • 2.2 创建配置文件
    • 三、Husky
      • 3.1 安装
      • 3.2 启动
      • 3.3 生成指令并执行
      • 3.4 通过commit-msg规范化提交信息
      • 3.5 通过pre-commit检测提交代码规范
    • 四、验证测试
      • 4.1 验证提交规范
      • 4.2 验证代码规范
    • 五、再进一步

一、Git Hooks

1.1 目标

在上篇文章中,我们使用git cz替代了git commit实现了规范化提交诉求,但是依然存在着有人会忘记使用的问题,那这篇文章就来看下,如何去解决这种问题?

在此之前,先来明确下最终实现的效果:

当《提交描述信息》不符合约定式提交规范时,阻止当前的提交,并抛出对应的错误提示

而实现这个目标,我们需要先了解一个概念,叫[Git hooks](https://git-scm.com/docs/githooks)(git 钩子、git毁掉方法),意思是指git在执行某个操作之前或之后进行一些其他额外的操作

而我们期望的阻止不合规的提交信息,就需要使用到hooks的钩子函数。

1.2 常用hooks

下面是整理的常用hooks

Git Hook调用时机说明
pre-applypathgit am执行前
applypath-msggit am执行前
post-applypathgit am执行后不影响git am结果
pre-commitgit commit执行前可以用git commit --no-verify绕过
cmmit-msggit commit执行前可以用git commit --no-verify绕过
post-commitgit commit执行后不影响git commit的结果
pre-merge-commitgit merge执行前可以用git merge --no-verify绕过
prepare-cmmit-msggit commit执行后,编辑器打开前
pre-rebasegit rebase执行前
post-checkoutgit checkout或git switch执行后如果不使用–no-checout参数,则在git clone 之后也会执行
post-mergegit commit执行后在执行git pull时也会被调用
pre-pushgit push执行前
pre-receivegit-receive-pack 执行前
post-rewritegit commit --amend或git rebase执行前
sendemail-validategit send-email执行前
updategit receive-pack执行后
post-receivegit receive-pack执行后不影响git-receive-pack的结果

1.3 核心钩子

在实际开发中,最常用的有两个:

Git Hook调用时机说明
pre-commitgit commit执行前,不接受任何参数,在获取提交日志消息并提交之前被调用可以通过git commit --no-verify绕过
cmmit-msggit commit执行前,可用于将消息规范化为某种项目标准格式,还可以用于在检查消息文件后拒绝提交可以通过git commit --no-verify绕过

简单来说:

  • commit-msg: 可以用来规划范标准格式,并且按需指定是否要拒绝本次提交
  • pre-commit:在提交前被调用,可以按需指定是否要拒绝本次提交

二、Commitlint

在上一节中,了解到git hooks的概念,那么接下来就是要git hooks去校验我们的提交信息。

首先介绍第一个工具commitlint,用来检查提交信息的。

2.1 安装

注:npm版本需要7.x及以上

在项目终端执行命令如下:

npm i @commitlint/config-conventional@12.1.4 @commitlint/cli@12.1.4 -D

2.2 创建配置文件

在项目根目录下,创建commitlint.config.js配置文件,内容如下:

module.exports = {
  // 继承的规则
  extends: ['@commitlint/config-conventional'],
  // 定义规则类型
  rules: {
    // type 类型定义,表示 git 提交的 type 必须在以下类型范围内
    'type-enum': [
      // 当前验证的错误级别
      2,
      // 在什么情况下进行验证
      'always',
      // 泛型内容,与cz-config.js中类型一致
      [
        'feat', // 新功能 feature
        'fix', // 修复 bug
        'docs', // 文档注释
        'style', // 代码格式(不影响代码运行的变动)
        'refactor', // 重构(既不增加新功能,也不是修复bug)
        'perf', // 性能优化
        'test', // 增加测试
        'chore', // 构建过程或辅助工具的变动
        'revert', // 回退
        'build' // 打包
      ]
    ],
    // subject 大小写不做校验
    'subject-case': [0]
  }
}

三、Husky

3.1 安装

安装依赖,如下:

npm install husky@7.0.1 -D

3.2 启动

启动hooks,生成.husky文件夹,执行命令如下:

npx husky install

执行完成后,在项目根目录下会生成.husky文件夹,如下:
在这里插入图片描述

3.3 生成指令并执行

package.json中配置prepare指令,如下:

"scripts": {
  ...
  "prepare": "husky install"
},

在终端窗口执行npm run prepare,如下:
··

3.4 通过commit-msg规范化提交信息

添加commitlinthookhusky中,在commit-msghooks下执行npx --no-install commitlint --edit "$1",完整命令如下:

npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'

执行完成后,会发现.husky中多了commit-msg文件,如下:
在这里插入图片描述

3.5 通过pre-commit检测提交代码规范

3.4完成了强制规范化的提交要求,现在不符合规范的提交信息,将不能够再提交!

也许,聪明的你已经发现,还缺少一个规范化的处理,那就是代码格式提交规范处理

在前面的文章中介绍过Eslint + Prettier来对代码格式做规范,但这只能再本地做处理,并且还需要手动在VSCode中配置自动保存,那么问题就来了,要是有人忘记配置了怎么办?代码格式乱七八糟的直接提交了怎么办?

因此,我们需要有一种方式来规避这种风险,那就是使用Husky配合Eslint来完成。本质上就是通过husky监测pre-commit钩子,在该钩子下执行npx eslint --ext .js,.vue src指令进行相关检测。

在项目终端中执行指令,完成commit时的hook,如下:

npx husky add .husky/pre-commit "npx eslint --ext .js,.vue src"

执行完成后,会发现在.husky中多了一个文件:
在这里插入图片描述

四、验证测试

4.1 验证提交规范

通过上面操作,不符合规范的commit将不再可提交,开始测试

执行git commit -m "commit test",报错如下:

 xxx@xxx-MacBook453  ~/Projects/VSCodeProjects/xxx   master ✚  git commit -m "commit test" 
⧗   input: commit test
✖   subject may not be empty [subject-empty]
✖   type may not be empty [type-empty]

✖   found 2 problems, 0 warnings
ⓘ   Get help: https://github.com/conventional-changelog/commitlint/#what-is-commitlint

husky - commit-msg hook exited with code 1 (error)

至此,不符合规范的commit将不能够再提交。

4.2 验证代码规范

首先,先通过设置保存时自动格式化关闭,如下:
在这里插入图片描述
然后,修改代码,将单引号修改为双引号,如下:

export default {
  name: "HomeView",
  components: {
    HelloWorld
  }
}

执行git commit提交,报错如下:
在这里插入图片描述
说明,我们在提交时,对代码格式规范检测也成功了。

五、再进一步

通过前面几节的介绍,目前想要提交代码,就要保证代码格式规范提交信息格式规范,那是不是已经万事大吉了呢?

当然不是,世界上从来不缺的就是懒人,错误的代码格式可能会抛出很多的ESLint错误,让人看的头皮发麻,严重影响程序猿的幸福指数。

那有么有一种办法,让程序猿0配置的前提下,哪怕代码格式再乱,都可以自动帮助其修复对应的问题并完成提交呢?

必须有!!!

欲知后事如何,请看下章讲解~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/42012.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

产品经理撰写需求文档

众所周知,需求文档的撰写是每位产品经理工作中必备的技能。 PRD文档没有标准的规范,也没有统一的模板,每个公司都不一样,并且每个人也不一样,这个取决于个人习惯和团队要求。 接下来主要讲作为一个入门的产品经理&…

使用小程序实现AI动漫脸特效

文章目录一、文章前言二、具体流程及准备三、开发步骤四、完整代码一、文章前言 最近在Dou音很火的AI绘画特效能够实现将人脸进行动漫化,让我们用小程序也制作一个吧。 二、具体流程及准备 2.1、注册百度开放平台及微信公众平台账号。 2.2、下载及安装微信Web开发者…

代码源每日一题div1 平方计数

平方计数 - 题目 - Daimayuan Online Judge 题意: 思路: 首先注意到暴力枚举一定超时,因此我们考虑只枚举一个指针,然后推一推式子降低另一个指针的复杂度 对于完全平方数这个条件,我们无法直接转换 即对于每一个a[…

sCrypt 合约中的椭圆曲线算法:第一部分

我们提出了一种新颖有效的方法,用于在脚本中计算椭圆曲线上的点加法和标量乘法。对于点加法,我们将超过 1MB 的脚本大小减少到约 400 字节。 椭圆曲线点加法 对于每个 i,每个点 Pi 由两个坐标 (xi, yi) 表示。要计算 P3 P1 P2,…

大数据培训教程Shuffle机制

Shuffle机制 Map方法之后,Reduce方法之前的数据处理过程称之为Shuffle。如图4-14所示。 图4-14 Shuffle机制 2 Partition分区 1、问题引出 要求将统计结果按照条件输出到不同文件中(分区)。比如:将统充结果 按照手机归属地不同省份输出到不同文件中(分区) 2、默…

环境土壤物理模型HYDRUS建模方法与多案例应用

HYDRUS是由著名土壤学家Rien van Genuchten和Jirka Simunek等人基于Windows系统界面开发的环境土壤物理模拟软件,是模拟一维和多维变饱和多孔介质的水流、溶质运移、根系吸水和溶质吸收、热量传输等的强有力工具。除基础功能以外,该模型还附有一系列扩展…

C/C++:双重循环中的break

break语句的执行只会导致其所在层的循环被中止。在一个嵌套的双重循环中,处于内层循环内的break被执行时,只会导致内层循环的中止,外层循环不受影响。 本文引用自作者编写的下述图书; 本文允许以个人学习、教学等目的引用、讲授或转载&#x…

Android -- 每日一问:如何理解 Gradle?Gradle 在 Android 的构建过程中有什么作用?

一、什么是 Gradle ? 一个像 Ant 一样的非常灵活的通用构建工具一种可切换的, 像 maven 一样的基于合约构建的框架支持强大的多工程构建支持强大的依赖管理(基于 ApacheIvy )支持已有的 maven 和 ivy 仓库支持传递性依赖管理, 而不需要远程仓库或者 pom.xml 或者 ivy 配置文件…

深度学习如何具有人类智能实现论述假说

🍿*★,*:.☆欢迎您/$:*.★* 🍿 正文 如图一所示 目前深度学习缺少的是 红色大框的部分 智能没有自我意识 同时 训练的方法也是不对的 直到最近的扩散模型 才刚刚有了一点起色 具体的训练方法 类似图二所示 假设人类获取信息只是通过眼睛 那么眼睛每次…

Redis数据库相关指令大合集

14天学习训练营导师课程: 郑为中《Vue和SpringBoot打造假日旅社管理系统》 努力是为了不平庸~ 学习有些时候是枯燥的,但收获的快乐是加倍的,欢迎记录下你的那些努力时刻(学习知识点/题解/项目实操/遇到的bug/等等)&am…

C. Tree Infection(二分)

Problem - 1665C - Codeforces 一棵树是一个没有循环的连接图。一棵有根的树有一个特殊的顶点,叫做根。一个顶点v(不同于根)的父顶点是指从根到顶点v的最短路径上的前一个顶点。 给你一棵有n个顶点的有根树。顶点1是根。最初,所有…

vue3 antd项目实战 表格的增删改查(一)input输入框根据关键字模糊搜索【纯前端filter过滤】

input输入框——关键字模糊搜索引言铺垫场景复现解决方案筛选的实现重置筛选信息优化处理(监听的实现)功能实现可能要用到的知识:vue3数据变化侦测&&信息筛选过滤.filter() .map() .forEach(). find()🔥vue3【watch检测/监…

10个实用的数据可视化的图表总结

用于深入了解数据的一些独特的数据可视化技术 可视化是一种方便的观察数据的方式,可以一目了然地了解数据块。我们经常使用柱状图、直方图、饼图、箱图、热图、散点图、线状图等。这些典型的图对于数据可视化是必不可少的。除了这些被广泛使用的图表外,…

JUC并发编程第四篇,Java中的各种锁之乐观锁和悲观锁、公平锁和非公平锁、可重入锁以及死锁基础

JUC并发编程第四篇,Java中的各种锁之乐观锁和悲观锁、公平锁和非公平锁、可重入锁以及死锁基础一、乐观锁和悲观锁二、公平锁和非公平锁三、可重入锁(递归锁)四、死锁一、乐观锁和悲观锁 乐观锁: 适合读操作多的场景,不加锁的特点能够使其读操…

《WEB前端框架开发技术》HTML5响应式旅游景区网站——榆林子州HTML+CSS+JavaScript

👨‍🎓学生HTML静态网页基础水平制作👩‍🎓,页面排版干净简洁。使用HTMLCSS页面布局设计,web大学生网页设计作业源码,这是一个不错的旅游网页制作,画面精明,排版整洁,内容…

Cerebral Cortex:调节γ振荡可以促进大脑连接性而改善认知障碍

摘要 老年痴呆症造成了巨大的全球经济负担,但目前还缺乏有效的治疗方法。最近的研究表明,脑电活动的伽马波段波,特别是40赫兹振荡,与高阶认知功能密切相关,可以激活小胶质细胞清除淀粉样蛋白-β沉积。本研究…

FCOS论文复现:通用物体检测算法

摘要:本案例代码是FCOS论文复现的体验案例,此模型为FCOS论文中所提出算法在ModelArts PyTorch框架下的实现。本代码支持FCOS ResNet-101在MS-COCO数据集上完整的训练和测试流程本文分享自华为云社区《通用物体检测算法 FCOS(目标检测/Pytorch)》&#…

UML/SysML和流浪地球的地球发动机

Lucky 2022-11-24 14:33 最近收到的公众号消息有不少是sysml内容,请问老师sysml和uml是什么关系,以后的趋势是sysml取代uml吗? UMLChina潘加宇 SysML和UML不冲突,也不存在取代的关系。 UML是信息系统的建模语言。“信息系统”…

“Signal”背后的bug与解决

背景 熟悉我的老朋友可能都知道,之前为了应对crash与anr,开源过一个“民间偏方”的库Signal,用于解决在发生crash或者anr时进行应用的重启,从而最大程度减少其坏影响。 在维护的过程中,发生过这样一件趣事&#xff0…

python合集1

我的首个python的合集啊~~ 完全给自己看啊 不喜喷了也不里你 一、一维插值 对现有数据进行拟合或插值是数学分析中常见的方式。 通过分析现有数据,得到一个连续的函数(也就是曲线);或者更密集的离散方程与已知数据互相吻合&…