![Drew Walters](/assets/img/avatar_default.png)
Currently, the Airskiff gate does not recognize failures because the gate script only verifies that an action lifecycle enters a COMPLETE state; however, a lifecycle in COMPLETE status is not always an indication of a successful deployment. This commit updates the wait_for_shipyard script to check the status of each action step and results in exit_code 1 if any steps failed. Change-Id: If5117c4638652b8d5b91fe73ede0f5e19a1e2cc1
56 lines
1.8 KiB
Bash
Executable File
56 lines
1.8 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Copyright 2018 AT&T Intellectual Property. All other rights reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License
|
|
|
|
set -e
|
|
|
|
: "${SHIPYARD:=../airship-shipyard/tools/shipyard.sh}"
|
|
|
|
ACTION=$(${SHIPYARD} get actions | grep -i "Processing" | awk '{ print $2 }')
|
|
|
|
echo -e "\nWaiting for $ACTION..."
|
|
|
|
while true; do
|
|
status=$(${SHIPYARD} describe "$ACTION" | grep -i "Lifecycle" | \
|
|
awk '{print $2}')
|
|
|
|
steps=$(${SHIPYARD} describe "$ACTION" | grep -i "step/" | \
|
|
awk '{print $3}')
|
|
|
|
# Verify lifecycle status
|
|
if [ "${status}" == "Failed" ]; then
|
|
echo -e "\n$ACTION FAILED\n"
|
|
${SHIPYARD} describe "${ACTION}"
|
|
exit 1
|
|
fi
|
|
|
|
if [ "${status}" == "Complete" ]; then
|
|
# Verify status of each action step
|
|
for step in $steps; do
|
|
if [ "${step}" == "failed" ]; then
|
|
echo -e "\n$ACTION FAILED\n"
|
|
${SHIPYARD} describe "${ACTION}"
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
echo -e "\n$ACTION completed SUCCESSFULLY\n"
|
|
${SHIPYARD} describe "${ACTION}"
|
|
exit 0
|
|
fi
|
|
|
|
sleep 10
|
|
done
|