1#!/usr/bin/env bash 2# shellcheck disable=SC2086 # we want word splitting 3 4set -ex 5 6if [ -z "$GPU_VERSION" ]; then 7 echo 'GPU_VERSION must be set to something like "llvmpipe" or "freedreno-a630" (the name used in your ci/gpu-version-*.txt)' 8 exit 1 9fi 10 11INSTALL="$PWD/install" 12 13# Set up the driver environment. 14export LD_LIBRARY_PATH="$INSTALL/lib/" 15export EGL_PLATFORM=surfaceless 16export VK_ICD_FILENAMES="$INSTALL/share/vulkan/icd.d/${VK_DRIVER}_icd.${VK_CPU:-$(uname -m)}.json" 17 18RESULTS=$PWD/${PIGLIT_RESULTS_DIR:-results} 19mkdir -p $RESULTS 20 21# Ensure Mesa Shader Cache resides on tmpfs. 22SHADER_CACHE_HOME=${XDG_CACHE_HOME:-${HOME}/.cache} 23SHADER_CACHE_DIR=${MESA_SHADER_CACHE_DIR:-${SHADER_CACHE_HOME}/mesa_shader_cache} 24 25findmnt -n tmpfs ${SHADER_CACHE_HOME} || findmnt -n tmpfs ${SHADER_CACHE_DIR} || { 26 mkdir -p ${SHADER_CACHE_DIR} 27 mount -t tmpfs -o nosuid,nodev,size=2G,mode=1755 tmpfs ${SHADER_CACHE_DIR} 28} 29 30if [ "$GALLIUM_DRIVER" = "virpipe" ]; then 31 # deqp is to use virpipe, and virgl_test_server llvmpipe 32 export GALLIUM_DRIVER="$GALLIUM_DRIVER" 33 34 VTEST_ARGS="--use-egl-surfaceless" 35 if [ "$VIRGL_HOST_API" = "GLES" ]; then 36 VTEST_ARGS="$VTEST_ARGS --use-gles" 37 fi 38 39 GALLIUM_DRIVER=llvmpipe \ 40 GALLIVM_PERF="nopt" \ 41 virgl_test_server $VTEST_ARGS >$RESULTS/vtest-log.txt 2>&1 & 42 43 sleep 1 44fi 45 46if [ -n "$PIGLIT_FRACTION" ] || [ -n "$CI_NODE_INDEX" ]; then 47 FRACTION=$((${PIGLIT_FRACTION:-1} * ${CI_NODE_TOTAL:-1})) 48PIGLIT_RUNNER_OPTIONS="$PIGLIT_RUNNER_OPTIONS --fraction $FRACTION" 49fi 50 51# If the job is parallel at the gitab job level, take the corresponding fraction 52# of the caselist. 53if [ -n "$CI_NODE_INDEX" ]; then 54 PIGLIT_RUNNER_OPTIONS="$PIGLIT_RUNNER_OPTIONS --fraction-start ${CI_NODE_INDEX}" 55fi 56 57if [ -e "$INSTALL/$GPU_VERSION-fails.txt" ]; then 58 PIGLIT_RUNNER_OPTIONS="$PIGLIT_RUNNER_OPTIONS --baseline $INSTALL/$GPU_VERSION-fails.txt" 59fi 60 61# Default to an empty known flakes file if it doesn't exist. 62touch $INSTALL/$GPU_VERSION-flakes.txt 63 64if [ -n "$VK_DRIVER" ] && [ -e "$INSTALL/$VK_DRIVER-skips.txt" ]; then 65 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/$VK_DRIVER-skips.txt" 66fi 67 68if [ -n "$GALLIUM_DRIVER" ] && [ -e "$INSTALL/$GALLIUM_DRIVER-skips.txt" ]; then 69 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/$GALLIUM_DRIVER-skips.txt" 70fi 71 72if [ -n "$DRIVER_NAME" ] && [ -e "$INSTALL/$DRIVER_NAME-skips.txt" ]; then 73 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/$DRIVER_NAME-skips.txt" 74fi 75 76if [ -e "$INSTALL/$GPU_VERSION-skips.txt" ]; then 77 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/$GPU_VERSION-skips.txt" 78fi 79 80if [ "$PIGLIT_PLATFORM" != "gbm" ] ; then 81 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/x11-skips.txt" 82fi 83 84if [ "$PIGLIT_PLATFORM" = "gbm" ]; then 85 PIGLIT_SKIPS="$PIGLIT_SKIPS $INSTALL/gbm-skips.txt" 86fi 87 88set +e 89 90piglit-runner \ 91 run \ 92 --piglit-folder /piglit \ 93 --output $RESULTS \ 94 --jobs ${FDO_CI_CONCURRENT:-4} \ 95 --skips $INSTALL/all-skips.txt $PIGLIT_SKIPS \ 96 --flakes $INSTALL/$GPU_VERSION-flakes.txt \ 97 --profile $PIGLIT_PROFILES \ 98 --process-isolation \ 99 $PIGLIT_RUNNER_OPTIONS \ 100 -v -v 101 102PIGLIT_EXITCODE=$? 103 104deqp-runner junit \ 105 --testsuite $PIGLIT_PROFILES \ 106 --results $RESULTS/failures.csv \ 107 --output $RESULTS/junit.xml \ 108 --limit 50 \ 109 --template "See $ARTIFACTS_BASE_URL/results/{{testcase}}.xml" 110 111# Report the flakes to the IRC channel for monitoring (if configured): 112if [ -n "$FLAKES_CHANNEL" ]; then 113 python3 $INSTALL/report-flakes.py \ 114 --host irc.oftc.net \ 115 --port 6667 \ 116 --results $RESULTS/results.csv \ 117 --known-flakes $INSTALL/$GPU_VERSION-flakes.txt \ 118 --channel "$FLAKES_CHANNEL" \ 119 --runner "$CI_RUNNER_DESCRIPTION" \ 120 --job "$CI_JOB_ID" \ 121 --url "$CI_JOB_URL" \ 122 --branch "${CI_MERGE_REQUEST_SOURCE_BRANCH_NAME:-$CI_COMMIT_BRANCH}" \ 123 --branch-title "${CI_MERGE_REQUEST_TITLE:-$CI_COMMIT_TITLE}" || true 124fi 125 126# Compress results.csv to save on bandwidth during the upload of artifacts to 127# GitLab. This reduces a full piglit run to 550 KB, down from 6 MB, and takes 128# 55ms on my Ryzen 5950X (with or without parallelism). 129zstd --rm -T0 -8qc $RESULTS/results.csv -o $RESULTS/results.csv.zst 130 131exit $PIGLIT_EXITCODE 132