【Git 学习笔记】第七章 用 git hook 钩子、别名、脚本提升日常工作效率(上)
创始人
2025-01-10 01:32:56
0

文章目录

  • 第七章 用 Git 钩子、别名、脚本提升日常工作效率(上)
    • 7.1 在提交消息中应用分支描述信息
    • 7.2 创建提交消息的动态模板
      • 例一:设置为拒绝提交
      • 例二:拒绝 --amend 提交
      • 例三:在提交注释中插入外部网页的请求内容
      • 知识拓展

第七章 用 Git 钩子、别名、脚本提升日常工作效率(上)

相关主题

  • 在提交消息中应用分支描述信息
  • 创建提交消息的动态模板
  • 在提交消息中应用外部信息
  • 阻止特定版本推送到远程库
  • 配置并使用 Git 别名
  • 配置并使用 Git 脚本
  • 设置并使用提交消息模板

为了在公司高效工作,产出的任何代码都该遵循一些原则或规范,让其顺利通过编译或单元测试;也应该在提交注释中加上一定的文字说明,比如已修复的 bug 的 ID 标识,或者相关实例的引用等等。绝大部分这类规则都可以通过脚本自动完成。既然如此,何不让它们在版本提交时自动进行呢?本章给出的示例,将向您展示如何在输出最终的提交注释前,将某处的数据转移到提交注释中,并可以学到一些实用方法,验证代码是否推送到想要的地方。最后介绍如何在 Git 中添加执行脚本。

Git 中的钩子(hook)是一段处理脚本,可以在特定事件发生时触发执行(如推送、提交、变基等)。如果脚本在退出时返回一个非零的值,则取消当前的 git 操作。这些 hook 脚本可以在克隆到本地的仓库文件夹 .git/hooks 下找到。如果文件扩展名是 .sample,表示当前不生效。

7.1 在提交消息中应用分支描述信息

在第三章介绍分支时,提到过为分支设置描述信息的命令,查看描述内容可通过如下命令完成:

$ git config --get branch. description 

本节示例演示怎样将分支描述信息应用到提交注释中。需要用到的 hook 钩子,叫作 prepare-commit-msg,在提交时触发。在实际弹出提交注释的编辑器之前,可以将钩子设置为您想要检查的任何内容。

示例中的脚本编写需要一定的 shell 基础。

jgit 库的 stable-3.2 分支为例,演示怎样在本地分支设置描述信息、进而创建 git 钩子了提取该信息到提交注释中:

# prepare repo and branch $ git clone https://github.com/eclipse-jgit/jgit chapter7.5 $ cd chapter7.5 $ git checkout -b descriptioInCommit  --track origin/stable-3.2 # Edit description $ git branch --edit-description descriptioInCommit ########### branch description start ########### Remote agent not connection to server      When the remote agent is trying to connect it will fail as network services are not up and running when remote agent tries the first time ########### branch description stop  ########### # Check the config $ git config --get branch.descriptioInCommit.description # edit hook file and make it executable (chmod +x) $ vim .git/hook/prepare-commit-msg # hook content: #!/bin/bash BRANCH=$(git branch | grep '*'| sed 's/*//g'|  sed 's/ //g') DESCRIPTION=$(git config --get branch.${BRANCH}.description) if [ -z "$DESCRIPTION" ]; then   echo "No desc for branch using default template" else   # replacing # with n   DESCRIPTION=$(echo "$DESCRIPTION" | sed 's/#/\n/g')   # replacing the first \n with \n\n   DESCRIPTION=$(echo "$DESCRIPTION" | sed 's/\n/\n\n/') # append default commit message DESCRIPTION=$(echo "$DESCRIPTION" && cat $1) # and write it all to the commit message echo "$DESCRIPTION" > $1 fi # Test with an empty commit $ git commit --allow-empty 

弹出的编辑器窗口情况如下:

弹出的编辑器窗口情况

# save and check it in git log: $ git log -1 commit a2aad6607b1d251a480bbf98b3e8ab4063266165 (HEAD -> descriptionInCommit) Author: SafeWinter  Date:   Sat Dec 18 19:35:08 2021 +0800      Remote agent not connection to server      When the remote agent is trying to connect     it will fail as network services are not up     and running when remote agent tries the first time # Checkout another new branch and test $ git checkout -b noDescriptionBranch $ git commit --allow-empty 

结果如下:

在这里插入图片描述

7.2 创建提交消息的动态模板

要让开发者做对的事,要么出于鼓励,要么出于强制。无论是哪一种,最终都需要开发者花时间来写出代码。这时如果需要一个不错的提交注释,可以试试 prepare-commit-msg 钩子来辅助开发人员。

本节示例将在提交注释中动态包含工作区状态的相关信息;此外,也能动态插入外部网页中的信息,比如 Bugzilla 中的缺陷相关的信息。

示例将从一个新仓库开始,git 库初始化的两种方式:

  1. 创建新仓库:git init
  2. 在指定目录中:git init

例一:设置为拒绝提交

$ git init chapter7 $ cd chapter7 $ ls .git/hooks/ $ cd .git/hooks/ $ mv prepare-commit-msg.sample prepare-commit-msg $ vim prepare-commit-msg #!/bin/bash  echo "I refuse to commit" exit 1 $ cd - $ git commit --allow-empty I refuse to commit $ git log -1 fatal: your current branch 'master' does not have any commits yet 

在这里插入图片描述

例二:拒绝 --amend 提交

prepare-commit-msg 钩子还可以接收参数,第一个参数为 .git/COMMIT_EDITMSG,第二个参数可以是 mergecommitsquash,或 template,具体取值取决于当时的场景。例如提交时拒绝使用 --amend 方式修订记录:

prepare-commit-msg

#!/bin/bash if [ "$2" == "commit" ]; then   echo "Not allowed to amend"   exit 1 fi 

测试一下效果:

$ echo "a lot of fish" > fishtank.txt $ git add fishtank.txt $ git commit -m "All my fishes are belong to us" $ git commit --amend Not allowed to amend 

Not allowed to amend

例三:在提交注释中插入外部网页的请求内容

修改 prepare-commit-msg 钩子如下:

#!/bin/bash if [ "$2" == "commit" ]; then    echo "Not allowed to amend"   exit 1 fi MESSAGE=$(curl -s http://whatthecommit.com/index.txt) echo "$MESSAGE" > $1 

第六行是从网站 http://whatthecommit.com 上请求一则提交消息放入 MESSAGE 变量。测试是否生效:

$ echo "gravel, plants, and food" >> fishtank.txt $ git add fishtank.txt $ git commit 

弹出的编辑器如下:

在这里插入图片描述

确认提交后,查看 git log -1 的输出结果:

查看最近一条 git log 日志情况

符合预期。实际工作中更常见的情形,是从一个外部系统,例如 TeamForge 拉取 bug 信息,再按一定的格式列举到提交注释中:

# You have the following artifacts assigned # Remove the # to add the artifact ID to the commit message      #[artf23456] Error 02 when using update handler on wlan #[artf43567] Enable Unicode characters for usernames #[artf23451] Use stars instead of & when keying pword 

这样方便开发人员快速根据 bug 情况提交版本注释,同时也方便后续系统根据格式化后的提交注释检索需要的信息。

知识拓展

prepare-commit-msg 钩子的功能扩展起来很轻松,关键是记住一点:获取某些信息的等待时间应该是值得的。通常容易检查的一件事是脏工作区(dirty work area)。我们可以在 prepare-commit-msg 钩子中使用 git status 的结果,来预测工作区的内容在提交后是否仍有被改动的文件:

$ git status $ echo "saltwater" >> fishtank.txt $ git status --porcelain  M fishtank.txt $ git add fishtank.txt $ git status --porcelain M  fishtank.txt $ echo "sharks and oysters" >> fishtank.txt $ git status --porcelain MM fishtank.txt 

注意第 4 行与第 7 行的细微差别,porcelain 参数是以对机器友好的形式呈现 git 库的当前状态:

  1. 第一个字符位:表示暂存区(staging area)的状态
  2. 第二个字符位:表示工作区(work area)的状态

因此可以利用这一特性,对 prepare-commit-msg 钩子做如下改造,判定仓库在提交后是否仍存在尚未提交的改动:

#!/bin/bash if [ "$2" == "commit" ]; then    echo "Not allowed to amend"   exit 1 fi MESSAGE=$(curl -s http://whatthecommit.com/index.txt) echo "$MESSAGE $(cat $1)" > $1  for file in $(git status --porcelain) do   if [ ${file:1:1} ]; then      DIRTY=1   fi done if [ "${DIRTY}" ]; then   # -i '' is not needed on Linux    sed "s/# Please/You have a dirty workarea are you sure you wish to commit ?\n&/" $1   echo "You have a dirty workarea are you sure you wish to commit ?" >> $1 fi 

第 3 行是检测第二个字符位是否为空。如果非空,提交后就会出现脏工作区。最后把相关提示插入提交注释中。来看看效果:

$ git commit 

弹出的编辑器内容如下:

实测弹出的编辑器内容情况

保存并直接提交后,原命令行的输出情况:

在这里插入图片描述

根据提示,工作区在提交后仍有变更。再到 git log 中查看:

$ git log -1 

再次查看 git log 提交记录情况

这样就能在提交的时候,检测工作区是否有遗漏的变更。

(此处与书中的结果略有不同,但殊途同归。原脚本的问题在于 echo "$MESSAGE" > $1 将原来的提示信息覆盖了,具体更正方案待定。)

为了方便下一节的演示,恢复到拓展之前的状态:

$ git reset --hard HEAD^ 

(此处有笔误,原书命令为 git reset --hard HEAD,末尾少了一个 ^

相关内容

热门资讯

方法辅助挂《Wepoke io... 方法辅助挂《Wepoke ios》软件透明挂!(透明挂)软件内置(2023已更新)(哔哩哔哩)方法辅...
2024版辅助挂《Wepoke... 2024版辅助挂《Wepoke实测》软件透明挂!(软件)透明挂系统(2025已更新)(哔哩哔哩)20...
必胜教程!(WPK数据)辅助透... 相信很多朋友都在电脑上玩过WPK吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家带来了WP...
第三方技巧!微扑克代打外挂辅助... 相信很多朋友都在电脑上玩过微扑克吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家带来了微扑...
一分钟快速了解《wEpoKe》... 一分钟快速了解《wEpoKe》软件透明挂!(软件)透明挂脚本(2022已更新)(哔哩哔哩);是一款可...
实测分享微扑克模拟器原来真的有... 实测分享微扑克模拟器原来真的有挂,太夸张了原来真的有挂,详细教程(有挂讲解);最新版2024是一款经...
4分钟了解!微扑克透明挂外挂辅... 4分钟了解!微扑克透明挂外挂辅助器插件挂(辅助挂)原来真的有挂(有挂详细)详细教程(哔哩哔哩);微扑...
4分钟了解微扑克AI原来真的有... 4分钟了解微扑克AI原来真的有挂,太坏了原来真的是有挂,详细教程(有挂猫腻),微扑克是用手机号来登录...
十分钟了解!wpk测试(wPk... 您好,wpk这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中...
科技揭秘《微扑克辅助插件挂》微... 科技揭秘《微扑克辅助插件挂》微扑克脚本外挂辅助器插件(哔哩哔哩);微扑克是一种具有地方特色的麻将游戏...