Git hook 开发和实践,提升自动化效率
我们使用 git 进行版本控制,期间会触发很多事件,这些利用好这些事件做好自动化,能帮我提升效率。git hook 就是一个这样的工具,在特定的事件中执行特定的钩子。
╰─➤ ls .git/hooks
applypatch-msg.sample post-update.sample pre-merge-commit.sample pre-receive.sample update.sample
commit-msg.sample pre-applypatch.sample pre-push.sample prepare-commit-msg.sample
fsmonitor-watchman.sample pre-commit.sample pre-rebase.sample push-to-checkout.sample
设置钩子路径
git 仓库的钩子存放路径由 core.hooksPath 控制,默认是在项目的 .git/hooks。它不能使用版本控制,我们可以修改这个变量来自定义钩子的存放路径。
mkdir githooks && cd githooks
# 复制一份代码示例
cp /path/to/a-git-project/.git/hooks/pre-push.sample pre-push
git config --global core.hooksPath /path/to/githooks
一个示例:输出创建MR的链接
hooks 本质上是一个shell文件,可以将以下代码加到文件中,以 pre-push 为示例:
# 输出创建合并分支请求的链接
current_project=$(git remote -v | grep origin | grep fetch | awk -F":" '{print $2}' | awk -F"." '{print $1}')
current_branch=$(git rev-parse --abbrev-ref HEAD)
echo "READY? 创建合并分支请求: https://codeup.aliyun.com/"$current_project"/changes/new?source_branch="$current_branch"&target_branch=develop"
exit 0
这个功能是在推送之前输出到 CodeUp(一个 git 托管系统)的创建合并请求的链接,可以在推送成功后,快速跳转到页面进行操作。