mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2024-11-27 04:04:23 +08:00
ef175ea594
If you're emitting a section header under set -x, you will see: + section_start foo "foo" + x_off [the section header] This is kind of annoying. Instead of trying to squash it everywhere by dancing around local set +x management, play some extremely stupid tricks with shells to make sure we never emit it. Signed-off-by: Daniel Stone <daniels@collabora.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/31602>
166 lines
4.9 KiB
Bash
Executable File
166 lines
4.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# shellcheck disable=SC1091 # paths only become valid at runtime
|
|
|
|
. "${SCRIPTS_DIR}/setup-test-env.sh"
|
|
|
|
set -e
|
|
|
|
comma_separated() {
|
|
local IFS=,
|
|
echo "$*"
|
|
}
|
|
|
|
if [[ -z "$VK_DRIVER" ]]; then
|
|
printf "VK_DRIVER is not defined\n"
|
|
exit 1
|
|
fi
|
|
|
|
INSTALL=$(realpath -s "$PWD"/install)
|
|
|
|
# Set up the driver environment.
|
|
# Modifiying here directly LD_LIBRARY_PATH may cause problems when
|
|
# using a command wrapper. Hence, we will just set it when running the
|
|
# command.
|
|
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$INSTALL/lib/:/vkd3d-proton-tests/x64/"
|
|
|
|
|
|
# Set the Vulkan driver to use.
|
|
ARCH=$(uname -m)
|
|
export VK_DRIVER_FILES="$INSTALL/share/vulkan/icd.d/${VK_DRIVER}_icd.$ARCH.json"
|
|
|
|
# Set environment for Wine.
|
|
export WINEDEBUG="-all"
|
|
export WINEPREFIX="/vkd3d-proton-wine64"
|
|
export WINEESYNC=1
|
|
|
|
if [ -f "$INSTALL/$GPU_VERSION-vkd3d-skips.txt" ]; then
|
|
mapfile -t skips < <(grep -vE '^#|^$' "$INSTALL/$GPU_VERSION-vkd3d-skips.txt")
|
|
VKD3D_TEST_EXCLUDE=$(comma_separated "${skips[@]}")
|
|
printf 'VKD3D_TEST_EXCLUDE=%s\n' "$VKD3D_TEST_EXCLUDE"
|
|
export VKD3D_TEST_EXCLUDE
|
|
fi
|
|
|
|
# Sanity check to ensure that our environment is sufficient to make our tests
|
|
# run against the Mesa built by CI, rather than any installed distro version.
|
|
MESA_VERSION=$(cat "$INSTALL/VERSION")
|
|
if ! vulkaninfo | grep driverInfo | tee /tmp/version.txt | grep -F "Mesa $MESA_VERSION"; then
|
|
printf "%s\n" "Found $(cat /tmp/version.txt), expected $MESA_VERSION"
|
|
exit 1
|
|
fi
|
|
|
|
# Gather the list expected failures
|
|
EXPECTATIONFILE="$RESULTS_DIR/$GPU_VERSION-vkd3d-fails.txt"
|
|
if [ -f "$INSTALL/$GPU_VERSION-vkd3d-fails.txt" ]; then
|
|
grep -vE '^(#|$)' "$INSTALL/$GPU_VERSION-vkd3d-fails.txt" | sort > "$EXPECTATIONFILE"
|
|
else
|
|
printf "%s\n" "$GPU_VERSION-vkd3d-fails.txt not found, assuming a \"no failures\" baseline."
|
|
touch "$EXPECTATIONFILE"
|
|
fi
|
|
|
|
if [ -f "$INSTALL/$GPU_VERSION-vkd3d-flakes.txt" ]; then
|
|
mapfile -t flakes < <(grep -vE '^#|^$' "$INSTALL/$GPU_VERSION-vkd3d-flakes.txt")
|
|
else
|
|
flakes=()
|
|
fi
|
|
|
|
# Some sanity checks before we start
|
|
mapfile -t flakes_dups < <(
|
|
[ ${#flakes[@]} -eq 0 ] ||
|
|
printf '%s\n' "${flakes[@]}" | sort | uniq -d
|
|
)
|
|
if [ ${#flakes_dups[@]} -gt 0 ]; then
|
|
printf >&2 'Duplicate flakes lines:\n'
|
|
printf >&2 ' %s\n' "${flakes_dups[@]}"
|
|
exit 1
|
|
fi
|
|
|
|
flakes_in_baseline=()
|
|
for flake in "${flakes[@]}"; do
|
|
if grep -qF "$flake" "$EXPECTATIONFILE"; then
|
|
flakes_in_baseline+=("$flake")
|
|
fi
|
|
done
|
|
if [ ${#flakes_in_baseline[@]} -gt 0 ]; then
|
|
printf >&2 "Flakes found in %s:\n" "$EXPECTATIONFILE"
|
|
printf >&2 ' %s\n' "${flakes_in_baseline[@]}"
|
|
exit 1
|
|
fi
|
|
|
|
printf "%s\n" "Running vkd3d-proton testsuite..."
|
|
|
|
LOGFILE="$RESULTS_DIR/vkd3d-proton-log.txt"
|
|
TEST_LOGS="$RESULTS_DIR/test-logs"
|
|
(cd /vkd3d-proton-tests && tests/test-runner.sh x64/bin/d3d12 --jobs "${FDO_CI_CONCURRENT:-4}" --output-dir "$TEST_LOGS" | tee "$LOGFILE")
|
|
|
|
printf '\n\n'
|
|
|
|
# Check if the executable finished (ie. no segfault).
|
|
if ! grep -E "^Finished" "$LOGFILE" > /dev/null; then
|
|
error "Failed, see ${ARTIFACTS_BASE_URL}/results/vkd3d-proton-log.txt"
|
|
exit 1
|
|
fi
|
|
|
|
# Print list of flakes seen this time
|
|
flakes_seen=()
|
|
for flake in "${flakes[@]}"; do
|
|
if grep -qF "FAILED $flake" "$LOGFILE"; then
|
|
flakes_seen+=("$flake")
|
|
fi
|
|
done
|
|
if [ ${#flakes_seen[@]} -gt 0 ]; then
|
|
# Keep this string and output format in line with the corresponding
|
|
# deqp-runner message
|
|
printf >&2 '\nSome known flakes found:\n'
|
|
printf >&2 ' %s\n' "${flakes_seen[@]}"
|
|
fi
|
|
|
|
# Collect all the failures
|
|
mapfile -t fails < <(grep -oE "^FAILED .+$" "$LOGFILE" | cut -d' ' -f2 | sort)
|
|
|
|
# Save test output for failed tests (before excluding flakes)
|
|
for failed_test in "${fails[@]}"; do
|
|
cp "$TEST_LOGS/$failed_test.log" "$RESULTS/$failed_test.log"
|
|
done
|
|
|
|
# Ignore flakes when comparing
|
|
for flake in "${flakes[@]}"; do
|
|
for idx in "${!fails[@]}"; do
|
|
grep -qF "$flake" <<< "${fails[$idx]}" && unset -v 'fails[$idx]'
|
|
done
|
|
done
|
|
|
|
RESULTSFILE="$RESULTS/$GPU_VERSION.txt"
|
|
for failed_test in "${fails[@]}"; do
|
|
if ! grep -qE "$failed_test end" "$RESULTS/$failed_test.log"; then
|
|
test_status=Crash
|
|
elif grep -qE "Test failed:" "$RESULTS/$failed_test.log"; then
|
|
test_status=Fail
|
|
else
|
|
test_status=Unknown
|
|
fi
|
|
printf '%s,%s\n' "$failed_test" "$test_status"
|
|
done > "$RESULTSFILE"
|
|
|
|
# Catch tests listed but not executed or not failing
|
|
mapfile -t expected_fail_lines < "$EXPECTATIONFILE"
|
|
for expected_fail_line in "${expected_fail_lines[@]}"; do
|
|
test_name=$(cut -d, -f1 <<< "$expected_fail_line")
|
|
if [ ! -f "$TEST_LOGS/$test_name.log" ]; then
|
|
test_status='UnexpectedImprovement(Skip)'
|
|
elif [ ! -f "$RESULTS/$test_name.log" ]; then
|
|
test_status='UnexpectedImprovement(Pass)'
|
|
else
|
|
continue
|
|
fi
|
|
printf '%s,%s\n' "$test_name" "$test_status"
|
|
done >> "$RESULTSFILE"
|
|
|
|
mapfile -t unexpected_results < <(comm -23 "$RESULTSFILE" "$EXPECTATIONFILE")
|
|
if [ ${#unexpected_results[@]} -gt 0 ]; then
|
|
printf >&2 '\nUnexpected results:\n'
|
|
printf >&2 ' %s\n' "${unexpected_results[@]}"
|
|
exit 1
|
|
fi
|
|
|
|
exit 0
|