Exit early with error if any jobs fail
I've tried a number of ways to do this, and this has been the simplest and most reliable. - Catches jobs that exit before calling the function. - Doesn't mess with the kill_jobs hook and leave orphan processes. - Bubbles up the exit code. Signed-off-by: Evan Lloyd New-Schmidt <evan@new-schmidt.com>
This commit is contained in:
parent
99c3b72e51
commit
af16cb6513
1 changed files with 22 additions and 3 deletions
25
run.sh
25
run.sh
|
@ -139,11 +139,30 @@ kill_jobs() {
|
|||
log "Killing background jobs"
|
||||
# shellcheck disable=SC2086 # PIDs are intentionally expanded.
|
||||
kill $pids
|
||||
log "Waiting for background jobs to stop"
|
||||
wait
|
||||
fi
|
||||
}
|
||||
|
||||
# Exit early with error if any jobs fail.
|
||||
watch_jobs() {
|
||||
# Must be provided, calling `jobs` clears any failed jobs from returning with `wait -n`.
|
||||
num_jobs="$1"
|
||||
if [ 0 -ge "$num_jobs" ]; then
|
||||
echo "num_jobs is not a positive integer: '$num_jobs'" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
for ((i=1; i <= num_jobs; i++)); do
|
||||
if wait -n; then
|
||||
: # Cannot use `! wait -n`, it changes the exit code.
|
||||
else
|
||||
status=$?
|
||||
log "ERROR: job failed with exit code $status"
|
||||
exit $status
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
trap 'kill_jobs' SIGINT SIGTERM EXIT
|
||||
|
||||
for dump in "${DUMP_FILES[@]}"; do
|
||||
|
@ -154,7 +173,7 @@ for dump in "${DUMP_FILES[@]}"; do
|
|||
"$OUTPUT_DIR" &
|
||||
done
|
||||
|
||||
wait
|
||||
watch_jobs "${#DUMP_FILES[@]}"
|
||||
|
||||
log "Beginning extraction of discovered QIDs"
|
||||
|
||||
|
@ -165,6 +184,6 @@ for dump in "${DUMP_FILES[@]}"; do
|
|||
"$OUTPUT_DIR" &
|
||||
done
|
||||
|
||||
wait
|
||||
watch_jobs "${#DUMP_FILES[@]}"
|
||||
|
||||
log "Finished"
|
||||
|
|
Loading…
Add table
Reference in a new issue