2023-04-14 21:25:55 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2023-04-14 22:36:55 +00:00
|
|
|
set -u
|
|
|
|
|
|
|
|
: $ZED_SERVER_URL
|
|
|
|
: $ZED_CLIENT_SECRET_TOKEN
|
|
|
|
|
2023-04-14 21:25:55 +00:00
|
|
|
# Compile the tests first
|
|
|
|
mkdir -p target
|
2023-04-14 22:36:55 +00:00
|
|
|
cargo test --release --lib --package collab --no-run
|
2023-04-14 21:25:55 +00:00
|
|
|
if [[ $? != 0 ]]; then
|
|
|
|
echo "Build failed"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
LOG_FILE=target/randomized-tests.log
|
2023-04-15 00:47:00 +00:00
|
|
|
MIN_PLAN=target/test-plan.min.json
|
2023-04-14 21:25:55 +00:00
|
|
|
export SAVE_PLAN=target/test-plan.json
|
|
|
|
export OPERATIONS=200
|
2023-04-14 22:36:55 +00:00
|
|
|
export ITERATIONS=100000
|
2023-04-14 21:25:55 +00:00
|
|
|
export SEED=$(od -A n -N 8 -t u8 /dev/urandom | xargs)
|
|
|
|
|
2023-04-14 22:36:55 +00:00
|
|
|
echo "Starting seed: ${SEED}"
|
|
|
|
|
|
|
|
cargo test --release --lib --package collab random 2>&1 > $LOG_FILE
|
2023-04-14 21:25:55 +00:00
|
|
|
if [[ $? == 0 ]]; then
|
|
|
|
echo "Tests passed"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2023-04-15 00:47:00 +00:00
|
|
|
failing_seed=$(script/randomized-test-minimize $SAVE_PLAN $MIN_PLAN)
|
|
|
|
|
2023-04-14 21:25:55 +00:00
|
|
|
# If the tests failed, find the failing seed in the logs
|
2023-04-14 22:36:55 +00:00
|
|
|
commit=$(git rev-parse HEAD)
|
2023-04-15 00:47:00 +00:00
|
|
|
failing_plan=$(cat $MIN_PLAN)
|
2023-04-14 22:36:55 +00:00
|
|
|
request="{
|
|
|
|
\"seed\": \"${failing_seed}\",
|
|
|
|
\"commit\": \"${commit}\",
|
|
|
|
\"token\": \"${ZED_CLIENT_SECRET_TOKEN}\",
|
|
|
|
\"plan\": ${failing_plan}
|
|
|
|
}"
|
|
|
|
|
|
|
|
echo "Reporting test failure."
|
|
|
|
echo $request
|
|
|
|
|
|
|
|
curl \
|
|
|
|
-X POST \
|
|
|
|
-H "Content-Type: application/json" \
|
|
|
|
-d "${request}" \
|
|
|
|
"${ZED_SERVER_URL}/api/randomized_test_failure"
|