功能:防止开发人员把不符合项目要求的代码提交到git仓库
先看看git下面有那些钩子
打开项目的.git/hooks/目录下查看
- applypatch-msg.sample
- pre-applypatch.sample
- pre-receive.sample
- commit-msg.sample
- pre-commit.sample
- prepare-commit-msg.sample
- fsmonitor-watchman.sample
- pre-push.sample
- update.sample
- post-update.sample
- pre-rebase.sample
只要将文件后缀.sample删除,钩子就会启用。
选择pre-push钩子,也就是git push之前会执行的脚本,脚本如下:
#!/bin/sh
./gradlew XXX && ./gradlew XXX #&&连接多个命令
status=$?
if [ "$status" = 0 ] ; then
echo "
....
....
Build Check Pass
....
....
"
exit 0
else
echo "
....
....
Build Check Failed!!
....
....
"
exit 1
fi
这里的./gradlew XXX && ./gradlew XXX是我们项目的编译命令,自行修改所需命令,为了尽快验证,不作clean操作。
如何同步git钩子:
由于.git/hooks/目录为每个工程本地私有的目录,并不会参与版本控制,因此需要一个机制在组内同步git hook设置。
首先在项目下新建hooks目录,将pre-push文件放在此目录下,此目录参与git版本控制;
然后在项目的build.gradle中新建如下task,每次编译之前都会执行一遍,将hooks目录下的文件复制到项目的.git/hooks目录下:
task copyHooks(type: Copy) {
println 'copyHooks task'
from("hooks") {
include "**"
}
into ".git/hooks"
}
preBuild.dependsOn copyHooks