65d3b5989b
When stderr is a terminal and supports color, print error messages from tests in red to make them stand out from the surrounding output.
87 lines
2.5 KiB
Bash
87 lines
2.5 KiB
Bash
#!/bin/sh
|
|
|
|
case @abi@ in
|
|
macho)
|
|
export DYLD_FALLBACK_LIBRARY_PATH="@objroot@lib"
|
|
;;
|
|
pecoff)
|
|
export PATH="${PATH}:@objroot@lib"
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
|
|
# Make a copy of the @JEMALLOC_CPREFIX@MALLOC_CONF passed in to this script, so
|
|
# it can be repeatedly concatenated with per test settings.
|
|
export MALLOC_CONF_ALL=${@JEMALLOC_CPREFIX@MALLOC_CONF}
|
|
# Concatenate the individual test's MALLOC_CONF and MALLOC_CONF_ALL.
|
|
export_malloc_conf() {
|
|
if [ "x${MALLOC_CONF}" != "x" -a "x${MALLOC_CONF_ALL}" != "x" ] ; then
|
|
export @JEMALLOC_CPREFIX@MALLOC_CONF="${MALLOC_CONF},${MALLOC_CONF_ALL}"
|
|
else
|
|
export @JEMALLOC_CPREFIX@MALLOC_CONF="${MALLOC_CONF}${MALLOC_CONF_ALL}"
|
|
fi
|
|
}
|
|
|
|
# Corresponds to test_status_t.
|
|
pass_code=0
|
|
skip_code=1
|
|
fail_code=2
|
|
|
|
pass_count=0
|
|
skip_count=0
|
|
fail_count=0
|
|
for t in $@; do
|
|
if [ $pass_count -ne 0 -o $skip_count -ne 0 -o $fail_count != 0 ] ; then
|
|
echo
|
|
fi
|
|
echo "=== ${t} ==="
|
|
if [ -e "@srcroot@${t}.sh" ] ; then
|
|
# Source the shell script corresponding to the test in a subshell and
|
|
# execute the test. This allows the shell script to set MALLOC_CONF, which
|
|
# is then used to set @JEMALLOC_CPREFIX@MALLOC_CONF (thus allowing the
|
|
# per test shell script to ignore the @JEMALLOC_CPREFIX@ detail).
|
|
enable_fill=@enable_fill@ \
|
|
enable_prof=@enable_prof@ \
|
|
. @srcroot@${t}.sh && \
|
|
export_malloc_conf && \
|
|
$JEMALLOC_TEST_PREFIX ${t}@exe@ @abs_srcroot@ @abs_objroot@
|
|
else
|
|
export MALLOC_CONF= && \
|
|
export_malloc_conf && \
|
|
$JEMALLOC_TEST_PREFIX ${t}@exe@ @abs_srcroot@ @abs_objroot@
|
|
fi
|
|
result_code=$?
|
|
case ${result_code} in
|
|
${pass_code})
|
|
pass_count=$((pass_count+1))
|
|
;;
|
|
${skip_code})
|
|
skip_count=$((skip_count+1))
|
|
;;
|
|
${fail_code})
|
|
fail_count=$((fail_count+1))
|
|
;;
|
|
*)
|
|
color_start=''
|
|
color_end=''
|
|
if [ -t 2 ] && tput colors >/dev/null 2>&1; then
|
|
color_start='\033[31m'
|
|
color_end='\033[0m'
|
|
fi
|
|
printf "${color_start}Test harness error: %s w/ MALLOC_CONF=\"%s\"${color_end}\n" "${t}" "${MALLOC_CONF}" 1>&2
|
|
printf "${color_start}Use prefix to debug, e.g. JEMALLOC_TEST_PREFIX=\"gdb --args\" sh test/test.sh %s${color_end}\n" "${t}" 1>&2
|
|
exit 1
|
|
esac
|
|
done
|
|
|
|
total_count=`expr ${pass_count} + ${skip_count} + ${fail_count}`
|
|
echo
|
|
echo "Test suite summary: pass: ${pass_count}/${total_count}, skip: ${skip_count}/${total_count}, fail: ${fail_count}/${total_count}"
|
|
|
|
if [ ${fail_count} -eq 0 ] ; then
|
|
exit 0
|
|
else
|
|
exit 1
|
|
fi
|