diff options
author | Paul Bonaud <paul.bonaud@fretlink.com> | 2019-08-01 10:38:53 +0200 |
---|---|---|
committer | Paul Bonaud <paul.bonaud@fretlink.com> | 2019-08-01 17:47:02 +0200 |
commit | 5da7f0d812714f9d2af03522d269bd2f462ee939 (patch) | |
tree | 876a2c852df1334d2435e40c29524f19ad2f67ed /files/clever-wait-deploy.sh | |
parent | e749969ff845089853920647b0da039938a2371c (diff) | |
download | ansible-clever-5da7f0d812714f9d2af03522d269bd2f462ee939.tar.gz ansible-clever-5da7f0d812714f9d2af03522d269bd2f462ee939.tar.zst ansible-clever-5da7f0d812714f9d2af03522d269bd2f462ee939.zip |
deploy: add a timeout in the polling waiting script
Diffstat (limited to 'files/clever-wait-deploy.sh')
-rwxr-xr-x | files/clever-wait-deploy.sh | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/files/clever-wait-deploy.sh b/files/clever-wait-deploy.sh index 98c5c37..a95c96f 100755 --- a/files/clever-wait-deploy.sh +++ b/files/clever-wait-deploy.sh | |||
@@ -4,18 +4,35 @@ set -ueo pipefail | |||
4 | 4 | ||
5 | VERBOSE=${VERBOSE:-} | 5 | VERBOSE=${VERBOSE:-} |
6 | lastCleverActivity="" | 6 | lastCleverActivity="" |
7 | timeout=2300 # 100 seconds less than the Ansible tasks' timeout | ||
8 | startTime=$(date +%s) | ||
7 | 9 | ||
8 | function cleverActivity { | 10 | function cleverActivity { |
9 | lastCleverActivity=$(clever activity) | 11 | lastCleverActivity=$(clever activity) |
10 | } | 12 | } |
11 | 13 | ||
12 | function ensure { | 14 | function ensure { |
13 | if [ "$?" == "1" ] | 15 | local lastReturnCode="$?" |
14 | then | 16 | |
15 | echo "✗ Deployment failed!" | ||
16 | fi | ||
17 | VERBOSE=true | 17 | VERBOSE=true |
18 | verbose | 18 | verbose |
19 | |||
20 | if isNotTimeout | ||
21 | then | ||
22 | if [ "$lastReturnCode" == "0" ] | ||
23 | then | ||
24 | echo "✓ Deployment done." | ||
25 | else | ||
26 | echo "✗ Deployment failed!" | ||
27 | fi | ||
28 | else | ||
29 | echo "⁈ Deployment timeout... Please check clever logs" | ||
30 | exit 1 | ||
31 | fi | ||
32 | } | ||
33 | |||
34 | function isNotTimeout { | ||
35 | [ $(($(date +%s) - startTime)) -lt $timeout ] | ||
19 | } | 36 | } |
20 | 37 | ||
21 | trap ensure EXIT ERR | 38 | trap ensure EXIT ERR |
@@ -52,7 +69,7 @@ function check { | |||
52 | local samplingTime=5 | 69 | local samplingTime=5 |
53 | 70 | ||
54 | echo "️▫ Waiting for deployment to start..." | 71 | echo "️▫ Waiting for deployment to start..." |
55 | while inactive "$commit" | 72 | while inactive "$commit" && isNotTimeout |
56 | do | 73 | do |
57 | verbose | 74 | verbose |
58 | sleep $samplingTime | 75 | sleep $samplingTime |
@@ -60,14 +77,13 @@ function check { | |||
60 | 77 | ||
61 | # Wait for completion | 78 | # Wait for completion |
62 | echo "▪ Deployment in progress..." | 79 | echo "▪ Deployment in progress..." |
63 | while deploying "$commit" | 80 | while deploying "$commit" && isNotTimeout |
64 | do | 81 | do |
65 | verbose | 82 | verbose |
66 | sleep $samplingTime | 83 | sleep $samplingTime |
67 | done | 84 | done |
68 | 85 | ||
69 | deployed "$commit" | 86 | deployed "$commit" |
70 | echo "✓ Deployment done." | ||
71 | } | 87 | } |
72 | 88 | ||
73 | function getHeadRev { | 89 | function getHeadRev { |