yum_install: fix awk return code
TIL: Similarly, all the END rules are merged, and executed when all the input is exhausted (or when an exit statement is executed). i.e. matching YUM_FAILED calls "exit", which falls through to the END rules which calls "exit result" ... which is zero. i.e. if the return code is 1 then we actually hide that and return with zero. This is rather annoying because errors that should halt to alert us of a package install failure pass through, only for you to have to debug much later on seemingly unrelated problems. This always sets "result" and thus should be returning the right thing. I've updated the documentation to hopefully make it clearer what's going on. Change-Id: Ia15b7dc55efb8d3e3e945241b67a468b8a914672
This commit is contained in:
parent
dec121114c
commit
a4705403aa
@ -1346,20 +1346,26 @@ function yum_install {
|
||||
|
||||
time_start "yum_install"
|
||||
|
||||
# - We run with LC_ALL=C so string matching *should* be OK
|
||||
# - Exit 1 if the failure might get better with a retry.
|
||||
# - Exit 2 if it is fatal.
|
||||
parse_yum_result=' \
|
||||
BEGIN { result=0 } \
|
||||
/^YUM_FAILED/ { exit $2 } \
|
||||
/^No package/ { result=2 } \
|
||||
/^Failed:/ { result=2 } \
|
||||
//{ print } \
|
||||
# This is a bit tricky, because yum -y assumes missing or failed
|
||||
# packages are OK (see [1]). We want devstack to stop if we are
|
||||
# installing missing packages.
|
||||
#
|
||||
# Thus we manually match on the output (stack.sh runs in a fixed
|
||||
# locale, so lang shouldn't change).
|
||||
#
|
||||
# If yum returns !0, we echo the result as "YUM_FAILED" and return
|
||||
# that from the awk (we're subverting -e with this trick).
|
||||
# Otherwise we use awk to look for failure strings and return "2"
|
||||
# to indicate a terminal failure.
|
||||
#
|
||||
# [1] https://bugzilla.redhat.com/show_bug.cgi?id=965567
|
||||
parse_yum_result=' \
|
||||
BEGIN { result=0 } \
|
||||
/^YUM_FAILED/ { result=$2 } \
|
||||
/^No package/ { result=2 } \
|
||||
/^Failed:/ { result=2 } \
|
||||
//{ print } \
|
||||
END { exit result }'
|
||||
|
||||
# The manual check for missing packages is because yum -y assumes
|
||||
# missing or failed packages are OK.
|
||||
# See https://bugzilla.redhat.com/show_bug.cgi?id=965567
|
||||
(sudo_with_proxies "${YUM:-yum}" install -y "$@" 2>&1 || echo YUM_FAILED $?) \
|
||||
| awk "$parse_yum_result" && result=$? || result=$?
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user