generated from jonico/pscale-workflow-helper-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwait-for-deploy-request-merged.sh
executable file
·52 lines (48 loc) · 1.9 KB
/
wait-for-deploy-request-merged.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
function wait_for_deploy_request_merged {
local retries=$1
local db=$2
local number=$3
local org=$4
# check whether fifth parameter is set, otherwise use default value
if [ -z "$5" ]; then
local max_timeout=600
else
local max_timeout=$5
fi
local count=0
local wait=1
echo "Checking if deploy request $number is ready for use..."
while true; do
local raw_output=`pscale deploy-request list "$db" --org "$org" --format json`
# check return code, if not 0 then error
if [ $? -ne 0 ]; then
echo "Error: pscale deploy-request list returned non-zero exit code $?: $raw_output"
return 1
fi
local output=`echo $raw_output | jq ".[] | select(.number == $number) | .deployment.state"`
# test whether output is pending, if so, increase wait timeout exponentially
if [ "$output" = "\"pending\"" ] || [ "$output" = "\"in_progress\"" ]; then
# increase wait variable exponentially but only if it is less than max_timeout
if [ $((wait * 2)) -le $max_timeout ]; then
wait=$((wait * 2))
else
wait=$max_timeout
fi
count=$((count+1))
if [ $count -ge $retries ]; then
echo "Deploy request $number is not ready after $retries retries. Exiting..."
return 2
fi
echo "Deploy-request $number is not merged yet. Current status:"
echo "show vitess_migrations\G" | pscale shell "$db" main --org "$org"
echo "Retrying in $wait seconds..."
sleep $wait
elif [ "$output" = "\"complete\"" ]; then
echo "Deploy-request $number has been merged successfully."
return 0
else
echo "Deploy-request $number with unknown status: $output"
return 3
fi
done
}