X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=run%2Ftests;h=0c5c8c0c358fc46a8071b7569bc5f3ab2d62007d;hp=b71cd6a66ccf92b3f55e8acb94e2d2476de0efd4;hb=HEAD;hpb=d33678b8e64de795becd3fa336dbbb099c691f58 diff --git a/run/tests b/run/tests index b71cd6a66..5db647af4 100755 --- a/run/tests +++ b/run/tests @@ -3,14 +3,54 @@ # e.g. --run_tests=foo set -e -PRIVATE_GIT="155d46e5c2a5a37c2269884b021c69b0d7d41f22" +PRIVATE_GIT="881c48805e352dfe150993814757ca974282be18" -if [ "$1" == "--check" ]; then - shift 1 - check=1 -else - check=0 -fi +type="" +check=0 +while [[ $# -gt 0 ]]; do + case $1 in + -e) + environment=$2 + shift + shift + ;; + --debug) + type="debug" + shift + ;; + --backtrace) + type="backtrace" + shift + ;; + --valgrind) + type="valgrind" + shift + ;; + --callgrind) + type="callgrind" + shift + ;; + --quiet) + type="quiet" + shift + ;; + --drd) + type="drd" + shift + ;; + --helgrind) + type="helgrind" + shift + ;; + --check) + check=1 + shift + ;; + *) + break + ;; + esac +done if [ "$(uname)" == "Linux" ]; then export LD_LIBRARY_PATH=build/src/lib:/usr/local/lib:/usr/local/lib64:$LD_LIBRARY_PATH @@ -19,6 +59,16 @@ if [ "$(uname)" == "Linux" ]; then if [ ! -f build/test/dcpomatic2_openssl ]; then ln -s ../../../openssl/apps/openssl build/test/dcpomatic2_openssl fi + export DCPOMATIC_TEST_TOOLS_PATH=/opt/asdcplib/bin + if [ -f /src/backports/dcp_inspect ]; then + export DCPOMATIC_DCP_INSPECT=/src/backports/dcp_inspect + fi + set +e + python3 -m clairmeta.cli --help > /dev/null 2>&1 + if [ "$?" == "0" ]; then + export DCPOMATIC_CLAIRMETA=1 + fi + set -e fi if [ "$(uname)" == "Darwin" ]; then @@ -32,7 +82,7 @@ if [ "$(uname)" == "Darwin" ]; then rm -f build/test/openssl ln -s ../../../openssl/apps/openssl build/test/openssl # SIP stops this being passed in from the caller's environment - export DYLD_LIBRARY_PATH=/Users/ci/osx-environment/x86_64/10.10/lib:/Users/ci/workspace/lib + export DYLD_LIBRARY_PATH=$environment/x86_64/10.10/lib:/Users/ci/workspace/lib # We need to find ffcmp in here export PATH=$PATH:/Users/ci/workspace/bin fi @@ -51,27 +101,20 @@ if [ "$check" == "1" ]; then popd fi -if [ "$1" == "--debug" ]; then - shift; +if [ "$type" == "debug" ]; then gdb --args build/test/unit-tests --catch_system_errors=no --log_level=test_suite $* -elif [ "$1" == "--backtrace" ]; then - shift; +elif [ "$type" == "backtrace" ]; then gdb -batch -ex "run" -ex "thread apply all bt" -return-child-result --args build/test/unit-tests --catch_system_errors=yes $* -elif [ "$1" == "--valgrind" ]; then - shift; +elif [ "$type" == "valgrind" ]; then # valgrind --tool="memcheck" --vgdb=yes --vgdb-error=0 build/test/unit-tests $* valgrind --tool="memcheck" --suppressions=suppressions build/test/unit-tests $* -elif [ "$1" == "--callgrind" ]; then - shift; +elif [ "$type" == "callgrind" ]; then valgrind --tool="callgrind" build/test/unit-tests $* -elif [ "$1" == "--quiet" ]; then - shift; +elif [ "$type" == "quiet" ]; then build/test/unit-tests --catch_system_errors=no $* -elif [ "$1" == "--drd" ]; then - shift; +elif [ "$type" == "drd" ]; then valgrind --tool="drd" build/test/unit-tests $* -elif [ "$1" == "--helgrind" ]; then - shift; +elif [ "$type" == "helgrind" ]; then valgrind --tool="helgrind" build/test/unit-tests $* else ulimit -c unlimited