aboutsummaryrefslogtreecommitdiffhomepage
path: root/files/clever-wait-deploy.sh
diff options
context:
space:
mode:
authorGaƫtan <36162164+gaetanfl@users.noreply.github.com>2018-02-23 18:10:48 +0100
committerGitHub <noreply@github.com>2018-02-23 18:10:48 +0100
commit4fdd3eb566b8b322789f74990181acc243ffb578 (patch)
tree4f0e9ffda46afe5e571d7071dd8e08c34a5b8928 /files/clever-wait-deploy.sh
parent4882b0d33ce42a3b01ac9689d1809e362f314d3f (diff)
parent8692bc2704f2a38890c93577e8f6743e611d5308 (diff)
downloadansible-clever-4fdd3eb566b8b322789f74990181acc243ffb578.tar.gz
ansible-clever-4fdd3eb566b8b322789f74990181acc243ffb578.tar.zst
ansible-clever-4fdd3eb566b8b322789f74990181acc243ffb578.zip
Merge pull request #1 from gaetanfl/first_try
Migrating single tasks file to a galaxy role
Diffstat (limited to 'files/clever-wait-deploy.sh')
-rw-r--r--files/clever-wait-deploy.sh50
1 files changed, 50 insertions, 0 deletions
diff --git a/files/clever-wait-deploy.sh b/files/clever-wait-deploy.sh
new file mode 100644
index 0000000..99088cc
--- /dev/null
+++ b/files/clever-wait-deploy.sh
@@ -0,0 +1,50 @@
1#!/bin/bash -e
2
3function deploying {
4 checkStatus "$1" "IN PROGRESS"
5}
6
7function deployed {
8 checkStatus "$1" "OK"
9}
10
11function inactive {
12 local commit="$1"
13 [[ "$(clever activity | grep "$commit" | grep "DEPLOY" | wc -l)" == "0" ]]
14}
15
16function checkStatus {
17 local commit="$1"
18 local status="$2"
19 [[ "$(clever activity | grep "$commit" | grep "${status}\s\+DEPLOY" | wc -l)" == "1" ]]
20}
21
22function check {
23 local timeout=600 # 10 minutes
24 local commit="$1"
25 local samplingTime=5
26
27 echo "Waiting for deployment start..."
28 while inactive "$commit" -a $timeout -gt 0
29 do
30 sleep $samplingTime
31 let "timeout-=$samplingTime"
32 done
33
34 # Wait for completion
35 echo "Deployement in progress..."
36 while deploying "$commit" -a $timeout -gt 0
37 do
38 sleep $samplingTime
39 let "timeout-=$samplingTime"
40 done
41
42 if [ $samplingTime -eq 0 ]
43 then
44 echo "Timeout"
45 fi
46
47 deployed "$commit"
48}
49
50check "$(git rev-parse HEAD)"