1 changed files with 90 additions and 0 deletions
@ -0,0 +1,90 @@ |
|||||
|
#!/bin/bash |
||||
|
#set -x |
||||
|
set -e |
||||
|
|
||||
|
source_path=/home/www/sync_code/sd_dsl/wms85std |
||||
|
source_git=( |
||||
|
"www@git.yvanui.com:jztd/wms85std.git" |
||||
|
"www@git.yvanui.com:lizhiwei/yvan-framework.git" |
||||
|
"www@git.yvanui.com:luoyifan/yvan-ui.git" |
||||
|
) |
||||
|
source_branch=( |
||||
|
"sd_dsl2" |
||||
|
"8.6" |
||||
|
"master" |
||||
|
) |
||||
|
source_position=( |
||||
|
"." |
||||
|
"yvan-framework" |
||||
|
"yvan-ui" |
||||
|
) |
||||
|
|
||||
|
target_path=/home/www/sync_code/sd_dsl/wms85std-sd |
||||
|
target_git=www@git.yvanui.com:lizhiwei/wms85std-sd.git |
||||
|
target_branch=master |
||||
|
target_position=. |
||||
|
|
||||
|
echoPrefix="\033[36m+" |
||||
|
echoSuffix="\033[0m" |
||||
|
|
||||
|
# 强制覆盖本地的代码 git fetch --all && git reset --hard origin/master |
||||
|
pullCode() { |
||||
|
# Usage: pullCode "codePath" "gitUrl" "branch" "position" |
||||
|
path=$1 # 代码保存路径 |
||||
|
gitUrl=$2 # git仓库地址 |
||||
|
branch=${3:-"master"} # git分支 |
||||
|
position=${4:-""} # 使用“.”clone到当前文件夹 |
||||
|
# 创建文件夹 |
||||
|
if [ ! -d "$path" ]; then |
||||
|
echo -e "$echoPrefix 请检查服务器是否正确,再执行: mkdir -p $path $echoSuffix" |
||||
|
exit |
||||
|
fi |
||||
|
|
||||
|
# git clone |
||||
|
echo -e "$echoPrefix cd $path $echoSuffix" |
||||
|
cd $path |
||||
|
if [ "`ls -A $path`" == "" ] || [ ! -d "$path/$position" ] || [ "`ls -A $path/$position`" = "" ]; then |
||||
|
echo -e "$echoPrefix git clone $gitUrl $position $echoSuffix" |
||||
|
git clone $gitUrl $position |
||||
|
fi |
||||
|
|
||||
|
# 进入文件夹,切换分支,git pull |
||||
|
if [ "$position" != "" ]; then |
||||
|
echo -e "$echoPrefix cd $position $echoSuffix" |
||||
|
cd $position |
||||
|
fi |
||||
|
echo -e "$echoPrefix git checkout $branch $echoSuffix" |
||||
|
git checkout $branch |
||||
|
echo -e "$echoPrefix git checkout . $echoSuffix" |
||||
|
git checkout . |
||||
|
echo -e "$echoPrefix git pull $echoSuffix" |
||||
|
if [ "`git pull`" == "Already up-to-date." ]; then |
||||
|
fi |
||||
|
echo "" |
||||
|
} |
||||
|
|
||||
|
source_pull() { |
||||
|
for ((idx=0; idx<${#source_git[@]}; idx++)); do |
||||
|
pullCode $source_path ${source_git[idx]} ${source_branch[idx]} ${source_position[idx]} |
||||
|
done |
||||
|
} |
||||
|
|
||||
|
source_build() { |
||||
|
# 构建 java |
||||
|
echo -e "$echoPrefix cd $source_path $echoSuffix" |
||||
|
cd $source_path |
||||
|
chmod +x gradlew |
||||
|
echo -e "$echoPrefix gradlew build -x test $echoSuffix" |
||||
|
./gradlew build -x test |
||||
|
echo "" |
||||
|
} |
||||
|
|
||||
|
target_pull() { |
||||
|
pullCode $target_path ${target_git} ${target_branch} ${target_position} |
||||
|
} |
||||
|
|
||||
|
source_pull |
||||
|
source_build |
||||
|
target_pull |
||||
|
|
||||
|
# bash <(curl -s http://git.yvanui.com/lizhiwei/jztd-deploy/raw/master/dsl/001sync_code.sh) |
||||
Loading…
Reference in new issue