2020-07-03 17:35:48 -04:00
|
|
|
#!/usr/bin/env bash
|
2020-07-14 20:11:58 -04:00
|
|
|
set -euxo pipefail
|
|
|
|
tracking_filename="ratchet-passing"
|
2020-07-03 17:35:48 -04:00
|
|
|
|
2020-07-14 20:11:58 -04:00
|
|
|
# Start somewhere predictable.
|
|
|
|
cd "$(dirname $0)"
|
|
|
|
base=$(pwd)
|
|
|
|
|
|
|
|
# Actually, though, trial outputs some things that are only gitignored in the project root.
|
|
|
|
cd "../.."
|
|
|
|
|
|
|
|
# Since both of the next calls are expected to exit non-0, relax our guard.
|
2020-07-03 17:35:48 -04:00
|
|
|
set +e
|
2020-07-14 20:11:58 -04:00
|
|
|
SUBUNITREPORTER_OUTPUT_PATH="$base/results.subunit2" trial --reporter subunitv2-file allmydata
|
|
|
|
subunit2junitxml < "$base/results.subunit2" > "$base/results.xml"
|
2020-07-03 17:35:48 -04:00
|
|
|
set -e
|
|
|
|
|
|
|
|
# Okay, now we're clear.
|
|
|
|
cd "$base"
|
|
|
|
|
|
|
|
# Make sure ratchet.py itself is clean.
|
|
|
|
python3 -m doctest ratchet.py
|
|
|
|
|
2020-07-14 20:11:58 -04:00
|
|
|
# Now see about Tahoe-LAFS (also expected to fail) ...
|
2020-07-03 17:35:48 -04:00
|
|
|
set +e
|
2020-07-14 20:11:58 -04:00
|
|
|
python3 ratchet.py up results.xml "$tracking_filename"
|
2020-07-03 17:35:48 -04:00
|
|
|
code=$?
|
|
|
|
set -e
|
|
|
|
|
|
|
|
# Emit a diff of the tracking file, to aid in the situation where changes are
|
|
|
|
# not discovered until CI (where TERM might `dumb`).
|
|
|
|
if [ $TERM = 'dumb' ]; then
|
|
|
|
export TERM=ansi
|
|
|
|
fi
|
2020-07-14 20:11:58 -04:00
|
|
|
git diff "$tracking_filename"
|
2020-07-03 17:35:48 -04:00
|
|
|
|
|
|
|
exit $code
|