[igt-dev] [PATCH i-g-t 1/2] run-tests.sh: allow to run without sudo
Lucas De Marchi
lucas.demarchi at intel.com
Mon Feb 26 18:50:29 UTC 2018
If the script is already running as root, it doens't need to be
executed through sudo. This also moves the calls to exec piglit to a
common function.
Signed-off-by: Lucas De Marchi <lucas.demarchi at intel.com>
---
scripts/run-tests.sh | 22 ++++++++++++++++++----
1 file changed, 18 insertions(+), 4 deletions(-)
diff --git a/scripts/run-tests.sh b/scripts/run-tests.sh
index a98e06ce..92c5578c 100755
--- a/scripts/run-tests.sh
+++ b/scripts/run-tests.sh
@@ -44,6 +44,20 @@ function download_piglit {
git clone git://anongit.freedesktop.org/piglit "$ROOT/piglit"
}
+function run_piglit # as-root <args>
+{
+ local need_root=$1
+ shift
+ local env sudo
+
+ if [ $need_root -a $EUID -ne 0 ]; then
+ sudo="sudo"
+ env="IGT_TEST_ROOT=\"$IGT_TEST_ROOT\" IGT_CONFIG_PATH=\"$IGT_CONFIG_PATH\""
+ fi
+
+ $sudo $env $PIGLIT "$@"
+}
+
function print_help {
echo "Usage: run-tests.sh [options]"
echo "Available options:"
@@ -111,18 +125,18 @@ if [ ! -x "$PIGLIT" ]; then
fi
if [ "x$LIST_TESTS" != "x" ]; then
- IGT_TEST_ROOT="$IGT_TEST_ROOT" IGT_CONFIG_PATH="$IGT_CONFIG_PATH" "$PIGLIT" print-cmd --format "{name}" igt
+ run_piglit 0 print-cmd --format "{name}" igt
exit
fi
if [ "x$RESUME" != "x" ]; then
- sudo IGT_TEST_ROOT="$IGT_TEST_ROOT" IGT_CONFIG_PATH="$IGT_CONFIG_PATH" "$PIGLIT" resume "$RESULTS" $NORETRY
+ run_piglit 1 resume "$RESULTS" $NORETRY
else
mkdir -p "$RESULTS"
- sudo IGT_TEST_ROOT="$IGT_TEST_ROOT" IGT_CONFIG_PATH="$IGT_CONFIG_PATH" "$PIGLIT" run igt --ignore-missing -o "$RESULTS" -s $VERBOSE $EXCLUDE $FILTER
+ run_piglit 1 run igt --ignore-missing -o "$RESULTS" -s $VERBOSE $EXCLUDE $FILTER
fi
if [ "$SUMMARY" == "html" ]; then
- "$PIGLIT" summary html --overwrite "$RESULTS/html" "$RESULTS"
+ run_piglit 0 summary html --overwrite "$RESULTS/html" "$RESULTS"
echo "HTML summary has been written to $RESULTS/html/index.html"
fi
--
2.14.3
More information about the igt-dev
mailing list