Browse Source

test: run remaining E2E testnets on run-multiple.sh failure (#5557)

Fixes #5542.
pull/5559/head
Erik Grinaker 4 years ago
committed by GitHub
parent
commit
e0e006d10f
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 20 additions and 6 deletions
  1. +20
    -6
      test/e2e/run-multiple.sh

+ 20
- 6
test/e2e/run-multiple.sh View File

@ -3,33 +3,47 @@
# This is a convenience script that takes a list of testnet manifests
# as arguments and runs each one of them sequentially. If a testnet
# fails, the container logs are dumped to stdout along with the testnet
# manifest.
# manifest, but the remaining testnets are still run.
#
# This is mostly used to run generated networks in nightly CI jobs.
#
# Don't set -e, since we explicitly check status codes ourselves.
set -u
set -euo pipefail
if [[ $# == 0 ]]; then
echo "Usage: $0 [MANIFEST...]" >&2
exit 1
fi
FAILED=()
for MANIFEST in "$@"; do
START=$SECONDS
echo "==> Running testnet $MANIFEST..."
./build/runner -f "$MANIFEST"
if [[ $? -ne 0 ]]; then
if ! ./build/runner -f "$MANIFEST"; then
echo "==> Testnet $MANIFEST failed, dumping manifest..."
cat "$MANIFEST"
echo "==> Dumping container logs for $MANIFEST..."
./build/runner -f "$MANIFEST" logs
exit 1
echo "==> Cleaning up failed testnet $MANIFEST..."
./build/runner -f "$MANIFEST" cleanup
FAILED+=("$MANIFEST")
fi
echo "==> Completed testnet $MANIFEST in $(( SECONDS - START ))s"
echo ""
done
if [[ ${#FAILED[@]} -ne 0 ]]; then
echo "${#FAILED[@]} testnets failed:"
for MANIFEST in "${FAILED[@]}"; do
echo "- $MANIFEST"
done
exit 1
else
echo "All testnets successful"
fi

Loading…
Cancel
Save