码迷,mamicode.com
首页 > 其他好文 > 详细

平常构建项目中会用到的一些脚本

时间:2019-11-15 10:43:45      阅读:79      评论:0      收藏:0      [点我收藏+]

标签:bsp   jenkin   分支   失败   dev   evel   bash   merge   out   

在jenkins 构建服务前校验分支是否合并了master 

#!/bin/bash
echo ${branches}

if [[ ${branches} != hotfix* && ${branches} != release* && ${branches} != feature* && ${branches} != master* ]];then

echo -e ‘\033[31m 分支格式不对,请获取hotfix 或者release分支 或者 feature分支 \033[0m‘
exit 1

fi

echo ‘切换到master主干‘

git checkout master

echo ‘获取master的最新代码‘

git pull origin master

echo ‘获取master的最新commitid‘

commid=`git rev-parse HEAD`

echo $commid

echo ‘获取上线分支是否包含master的最新commitid‘

result=`git branch -a --contains ${commid}`


if [[ $result =~ ${branches} ]];then
echo ‘可以打包上线‘
git checkout ${branches}
git pull origin ${branches}

else
echo -e ‘\033[31m 你又没合并master ,请自行检查合并 \033[0m‘
exit 1

echo $result

fi

*********************************8

上线结束后,自动进行代码合并

if [[ ${branches} == master ]];then
echo ‘代码合并失败,请使用非master分支‘
exit 0
fi

if [[ ${branches} != hotfix* && ${branches} != release* ]];then

echo -e ‘\033[31m 分支格式不对,请获取hotfix 或者release分支,不进行合并 \033[0m‘
exit 1

fi

echo ‘切换到master主干‘

git checkout master

echo ‘获取master的最新代码‘

git pull origin master

echo ‘获取master的最新commitid‘

commid=`git rev-parse HEAD`

echo $commid

echo ‘获取上线分支是否包含master的最新commitid‘

result=`git branch -a --contains ${commid}|grep ${branches}`
echo $result
if [ $result != "" ];then
echo ‘开始执行合并代码到master, develop‘
git checkout ${branches}
git pull origin ${branches}
git checkout master
git pull origin master
git merge ${branches}
git push origin master
git checkout develop
git pull origin develop
git merge ${branches}
git push origin develop
else
echo -e ‘\033[31m 上线包不包含master分支,上线包有问题 \033[0m‘
exit 1echo $result

************************************

 

平常构建项目中会用到的一些脚本

标签:bsp   jenkin   分支   失败   dev   evel   bash   merge   out   

原文地址:https://www.cnblogs.com/yingchen/p/11864863.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!