aboutsummaryrefslogtreecommitdiff
path: root/test/run_test.sh
blob: f758ec879117b55c0819734a072bd203abaa57fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/usr/bin/env bash
# vim: set ft=sh sw=4 sts=4 et :

testname=${2:-${1}}
testname=${testname%.rb}
testname=${testname%.py}
testname=${testname%.bash}

if test -f "$TEST_SCRIPT_DIR""${testname}"_"cleanup.sh" ; then
    echo ">>> cleanup for test ${testname}"
    if ! "$TEST_SCRIPT_DIR""${testname}"_"cleanup.sh" ; then
        echo ">>> exiting with error for test ${testname}"
        exit 255
    fi
else
    echo ">>> No $TEST_SCRIPT_DIR${testname}_cleanup.sh to run"
fi

if test -f "$TEST_SCRIPT_DIR""${testname}"_"setup.sh" ; then
    echo ">>> setup for test ${testname}"
    if ! "$TEST_SCRIPT_DIR""${testname}"_"setup.sh" ; then
        echo ">>> exiting with error for test ${testname}"
        exit 255
    fi
else
    echo ">>> No $TEST_SCRIPT_DIR${testname}_setup.sh to run"
fi

echo ">>> test ${testname}"
if [[ -n "${TEST_OUTPUT_WRAPPER}" ]] ; then
    $TEST_OUTPUT_WRAPPER --stdout-prefix "${testname#./}> " --stderr-prefix \
        "${testname#./}> " --wrap-blanks -- ${@}
    code=$?
else
    ${@}
    code=$?
fi

if [[ 0 != ${code} ]] ; then
    echo ">>> test ${testname} returned ${code}"
    if [[ -z "${PALUDIS_TESTS_RERUN_VERBOSELY}" ]] ; then
        out=`pwd`/${testname#./}.epicfail
        echo ">>> rerunning test ${testname} verbosely redirected to ${out}"
        env PALUDIS_TESTS_RERUN_VERBOSELY=no PALUDIS_TESTS_KEEP_STDERR=yes \
            PALUDIS_TESTS_KEEP_LOG=yes $@ > $out 2>&1
        echo ">>> saved output of verbose ${testname} rerun to ${out}"
    fi
    echo ">>> exiting with error for test ${testname}"
    exit 255
fi

if test -f "$TEST_SCRIPT_DIR""${testname}"_"cleanup.sh" ; then
    echo ">>> cleanup for test ${testname}"
    if ! "$TEST_SCRIPT_DIR""${testname}"_"cleanup.sh" ; then
        echo ">>> exiting with error for test ${testname}"
        exit 255
    fi
else
    echo ">>> No $TEST_SCRIPT_DIR${testname}_cleanup.sh to run"
fi

echo ">>> exiting with success for test ${testname}"
exit 0