0


Git钩子Hook功能

💾 Hook 钩子


目录

🔔 简介

Git Hooks是Git内置的一种机制,允许在特定事件发生时执行自定义脚本。Git Hook可以在客户端和服务器端配置,经常用于自动化任务、增强开发流程以及确保代码质量。


🔔 常见类型

📄项目📜类型💡含义客户端
Hookspre-commit在提交前运行prepare-commit-msg在生成提交信息前运行commit-msg在提交信息编辑完成后运行post-commit在提交完成后运行pre-rebase在变基操作前运行pre-push在推送代码前运行服务器
Hookspre-receive在服务器端接收到推送数据前运行update在服务器端更新每个分支前运行post-receive在服务器端接收推送数据后运行


🔔 如何配置

📄 个人配置:

将个人使用的Git Hook脚本存放在

.git/hooks

目录下。该目录默认包含一些示例脚本,可以将这些脚本重命名或替换为自定义脚本。

📄 团队配置:

将所有团队成员需要的Hook脚本放在项目中的某个目录(例如

hooks

),然后在项目根目录的.git配置文件中配置

core.hooksPath

指向该目录。

配置命令:

git config core.hooksPath hooks

.git

目录下的

config

文件内容可看到多了

hooksPath = hooks

的字段:

[core]...
    hooksPath = hooks

取消配置命令:

git config --unset core.hooksPath

🔔 使用场景

  • 💡 代码格式检查:pre-commit在提交之前使用工具检查代码格式是否符合团队规范。
  • 💡 运行单元测试:pre-commit在提交之前运行单元测试,确保新代码不会破坏现有功能。
  • 💡 提交信息检查:commit-msg确保提交信息符合特定格式或包含必要的内容。
  • 💡 代码审查:提交或推送代码时触发代码审查工具,自动化代码审查流程。
  • 💡 自动部署:在推送代码到特定分支后结合CI/CD工具自动部署到测试或生产环境。

🔔 示例

以下是使用

pre-commit

作为钩子的示例。每次提交前会执行该钩子。

📄 项目的结构:

GitHooksExample
├─ CMakeLists.txt
├─ hooks
│    └─ pre-commit
├─ scripts
│    └─ build.py
└─ src
       └─ main.cpp

在hooks目录(使用

git config core.hooksPath hooks

命令配置指向该目录)下有一个

pre-commit

的钩子。
在scripts目录下有个Python脚本,该脚本会被钩子使用,执行的时候会构建项目。

📄 **

pre-commit

的内容:**

#!/bin/bash# 如果src目录下存在修改的文件就运行Python脚本changes_files=$(gitdiff --name-only --relative=src)if[-n"$changes_files"];thenecho"$changes_files" files changed, running build script...
  python  scripts/build.py
  if[$?-ne0];thenecho"Build failed. Aborting commit."exit1fielseecho"Skipping build: no changes in src directory."fi# 允许继续exit0

📄 **

build.py

的内容:**

import os
import sys
import subprocess

VCINSTALLDIR ="C:/Program Files/Microsoft Visual Studio/2022/Community/VC/Auxiliary/Build/vcvarsall.bat"

current_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
build_dir = os.path.normpath(current_dir +"/build")
os.makedirs(build_dir, exist_ok=True)

build_cmd =[f'{os.path.normpath(VCINSTALLDIR)}','x86']

cmake_cmd =[f'cmake',f'-DCMAKE_BUILD_TYPE=RelWithDebInfo',f'-DCMAKE_EXPORT_COMPILE_COMMANDS:BOOL=TRUE',f'-S{current_dir}',f'-B{build_dir}','-G','Ninja']
cmake_build_cmd =[f'cmake',f'--build',f'{build_dir}',f'--config',f'RelWithDebInfo']

cmd = build_cmd +['&&']+ cmake_cmd +['&&']+ cmake_build_cmd

try:
    subprocess.run(cmd, shell=True, check=True)print("编译成功!")
    sys.exit(0)except subprocess.CalledProcessError as e:print("编译失败:", e)
    sys.exit(1)

📄 提交时触发hooks:
在这里插入图片描述

可以看到在提交前对工程进行构建编译,编译完成后才会提交。

📄 提交异常代码时触发hooks:

接下来演示一下当

main.cpp

文件代码异常时的提交:

#include<iostream>intmain(){
    std::cout <<"Hello, World!"<< std::endl;//异常代码, 未定义 test
    test =1;return0;}

进行提交时,可以看到编译构建失败,提交中止:
在这里插入图片描述

这样可以避免提交了一个错误的代码。减少错误。


本文件示例工程源码下载https://download.csdn.net/download/qq_41898196/89543736

标签: git hooks 自动化

本文转载自: https://blog.csdn.net/qq_41898196/article/details/140265279
版权归原作者 码农葫芦侠 所有, 如有侵权,请联系我们删除。

“Git钩子Hook功能”的评论:

还没有评论