mirror of
https://github.com/kanaka/mal.git
synced 2024-10-26 22:28:26 +03:00
84 lines
2.4 KiB
Bash
Executable File
84 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -ex
|
|
|
|
ACTION=${1}
|
|
IMPL=${2}
|
|
|
|
die() { local ret=$1; shift; echo >&2 "${*}"; exit $ret; }
|
|
|
|
# Environment variable configuration
|
|
BUILD_IMPL=${BUILD_IMPL:-${IMPL}}
|
|
|
|
if [ "${DO_SELF_HOST}" ]; then
|
|
MAL_IMPL=${IMPL}
|
|
IMPL=mal
|
|
fi
|
|
|
|
if [ "${DO_HARD}" ]; then
|
|
TEST_OPTS="${TEST_OPTS} --hard"
|
|
fi
|
|
|
|
raw_mode_var=${MAL_IMPL:-${IMPL}}_MODE
|
|
mode_var=${raw_mode_var/-/__}
|
|
mode_var=${mode_var/./__}
|
|
mode_val=${!mode_var}
|
|
|
|
MAKE="make ${mode_val:+${mode_var}=${mode_val}}"
|
|
|
|
log_prefix="${ACTION}${REGRESS:+-regress}-${IMPL}${mode_val:+-${mode_val}}${MAL_IMPL:+-${MAL_IMPL}}"
|
|
TEST_OPTS="${TEST_OPTS} --debug-file ../../${log_prefix}.debug"
|
|
|
|
# Log everything below this point:
|
|
exec &> >(tee ./${log_prefix}.log)
|
|
|
|
if [ "${NO_PERF}" -a "${ACTION}" = "perf" ]; then
|
|
die 0 "Skipping perf test"
|
|
fi
|
|
if [ "${NO_SELF_HOST}" -a "${DO_SELF_HOST}" ]; then
|
|
die 0 "Skipping ${ACTION} of ${MAL_IMPL} self-host"
|
|
fi
|
|
if [ "${NO_SELF_HOST_PERF}" -a "${DO_SELF_HOST}" -a "${ACTION}" = "perf" ]; then
|
|
die 0 "Skipping only perf test for ${MAL_IMPL} self-host"
|
|
fi
|
|
|
|
echo "ACTION: ${ACTION}"
|
|
echo "IMPL: ${IMPL}"
|
|
echo "BUILD_IMPL: ${BUILD_IMPL}"
|
|
echo "MAL_IMPL: ${MAL_IMPL}"
|
|
echo "TEST_OPTS: ${TEST_OPTS}"
|
|
|
|
# If NO_DOCKER is blank then launch use a docker image, otherwise use
|
|
# the Travis/Github Actions image/tools directly.
|
|
if [ -z "${NO_DOCKER}" ]; then
|
|
img_impl=$(echo "${MAL_IMPL:-${IMPL}}" | tr '[:upper:]' '[:lower:]')
|
|
# We could just use make DOCKERIZE=1 instead but that does add
|
|
# non-trivial startup overhead for each step.
|
|
MAKE="docker run -i -u $(id -u) -v `pwd`:/mal kanaka/mal-test-${img_impl%%-mal} ${MAKE}"
|
|
fi
|
|
|
|
case "${ACTION}" in
|
|
build)
|
|
# rpython often fails on step9 in compute_vars_longevity
|
|
# so build step9, then continue with the full build
|
|
if [ "${BUILD_IMPL}" = "rpython" ]; then
|
|
${MAKE} -C "impls/${BUILD_IMPL}" step9_try || true
|
|
fi
|
|
${MAKE} -C "impls/${BUILD_IMPL}"
|
|
;;
|
|
test|perf)
|
|
[ "${ACTION}" = "perf" ] && STEP=
|
|
if ! ${MAKE} TEST_OPTS="${TEST_OPTS}" \
|
|
${MAL_IMPL:+MAL_IMPL=${MAL_IMPL}} \
|
|
${REGRESS:+REGRESS=${REGRESS}} \
|
|
${HARD:+HARD=${HARD}} \
|
|
${DEFERRABLE:+DEFERRABLE=${DEFERRABLE}} \
|
|
${OPTIONAL:+OPTIONAL=${OPTIONAL}} \
|
|
${ACTION}^${IMPL}${STEP:+^${STEP}}; then
|
|
# print debug-file on error
|
|
cat ${log_prefix}.debug
|
|
false
|
|
fi
|
|
;;
|
|
esac
|