2019-04-19 17:31:01 +02:00
|
|
|
#!/usr/bin/env bash
|
2020-12-27 14:37:07 +01:00
|
|
|
#############################################################
|
|
|
|
#
|
|
|
|
# File: dev/all-tests.sh
|
|
|
|
#
|
|
|
|
# Description: run all tests, exit after failed test
|
|
|
|
#
|
2021-02-04 18:13:32 +01:00
|
|
|
#### $$VERSION$$ v1.40-0-gf9dab50
|
2020-12-27 14:37:07 +01:00
|
|
|
#############################################################
|
2019-04-19 17:31:01 +02:00
|
|
|
|
2021-01-15 14:06:10 +01:00
|
|
|
#shellcheck disable=SC1090
|
|
|
|
source "${0%/*}/dev.inc.sh"
|
2019-04-19 17:31:01 +02:00
|
|
|
|
2020-12-27 14:37:07 +01:00
|
|
|
##########################
|
2019-04-19 17:31:01 +02:00
|
|
|
# create test environment
|
|
|
|
TESTENV="/tmp/bashbot.test$$"
|
2019-04-22 10:19:16 +02:00
|
|
|
mkdir "${TESTENV}"
|
2019-04-22 20:34:43 +02:00
|
|
|
cp -r ./* "${TESTENV}"
|
2019-04-20 21:09:36 +02:00
|
|
|
cd "test" || exit 1
|
2019-04-20 16:26:16 +02:00
|
|
|
|
2020-12-04 21:35:21 +01:00
|
|
|
# delete possible config
|
2020-12-13 18:07:27 +01:00
|
|
|
rm -f "${TESTENV}/botconfig.jssh" "${TESTENV}/botacl" 2>/dev/null
|
2020-12-04 21:35:21 +01:00
|
|
|
|
2021-01-01 19:25:25 +01:00
|
|
|
# mkdir needed dirs
|
|
|
|
mkdir "${TESTENV}/data-bot-bash"
|
|
|
|
|
2020-12-27 14:37:07 +01:00
|
|
|
# inject JSON.sh
|
|
|
|
mkdir "${TESTENV}/JSON.sh"
|
|
|
|
curl -sL "https://cdn.jsdelivr.net/gh/dominictarr/JSON.sh/JSON.sh" >"${TESTENV}/JSON.sh/JSON.sh"
|
|
|
|
chmod +x "${TESTENV}/JSON.sh/JSON.sh"
|
|
|
|
|
|
|
|
########################
|
|
|
|
#prepare and run tests
|
2019-04-19 17:31:01 +02:00
|
|
|
#set -e
|
|
|
|
fail=0
|
|
|
|
tests=0
|
|
|
|
passed=0
|
|
|
|
#all_tests=${__dirname:}
|
2021-01-01 11:27:54 +01:00
|
|
|
#printf PLAN ${#all_tests}
|
2019-04-22 20:34:43 +02:00
|
|
|
for test in $(find ./*-test.sh | sort -u) ;
|
2019-04-19 17:31:01 +02:00
|
|
|
do
|
2020-09-06 18:56:13 +02:00
|
|
|
[ "${test}" = "dev/all-tests.sh" ] && continue
|
2019-04-19 17:31:01 +02:00
|
|
|
[ ! -x "${test}" ] && continue
|
|
|
|
tests=$((tests+1))
|
2021-01-01 11:27:54 +01:00
|
|
|
printf "TEST: %s\n" "${test}"
|
2019-04-19 17:31:01 +02:00
|
|
|
"${test}" "${TESTENV}"
|
|
|
|
ret=$?
|
2021-01-03 12:06:39 +01:00
|
|
|
set +e
|
2021-01-05 11:40:28 +01:00
|
|
|
if [ "${ret}" -eq 0 ] ; then
|
2021-01-01 11:27:54 +01:00
|
|
|
printf "OK: ---- %s\n" "${test}"
|
2019-04-19 17:31:01 +02:00
|
|
|
passed=$((passed+1))
|
|
|
|
else
|
2021-01-01 11:27:54 +01:00
|
|
|
printf "FAIL: %s\n" "${test} ${fail}"
|
2019-04-19 17:31:01 +02:00
|
|
|
fail=$((fail+ret))
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2020-12-27 14:37:07 +01:00
|
|
|
###########################
|
|
|
|
# cleanup depending on test state
|
2021-01-05 11:40:28 +01:00
|
|
|
if [ "${fail}" -eq 0 ]; then
|
2021-01-01 11:27:54 +01:00
|
|
|
printf 'SUCCESS '
|
2019-04-19 17:31:01 +02:00
|
|
|
exitcode=0
|
2020-08-05 07:41:49 +02:00
|
|
|
rm -rf "${TESTENV}"
|
2019-04-19 17:31:01 +02:00
|
|
|
else
|
2021-01-01 11:27:54 +01:00
|
|
|
printf 'FAILURE '
|
2019-04-19 17:31:01 +02:00
|
|
|
exitcode=1
|
2020-12-31 22:56:58 +01:00
|
|
|
rm -rf "${TESTENV}/test"
|
|
|
|
find "${TESTENV}/"* ! -name '[a-z]-*' -delete
|
2019-04-19 17:31:01 +02:00
|
|
|
fi
|
|
|
|
|
2020-12-27 14:37:07 +01:00
|
|
|
#########################
|
|
|
|
# show test result and test logs
|
2021-01-01 11:27:54 +01:00
|
|
|
printf "%s\n\n" "${passed} / ${tests}"
|
|
|
|
[ -d "${TESTENV}" ] && printf "Logfiles from run are in %s\n" "${TESTENV}"
|
2019-04-26 15:07:07 +02:00
|
|
|
|
2021-01-01 11:27:54 +01:00
|
|
|
ls -ld /tmp/bashbot.test* 2>/dev/null && printf "Do not forget to delete bashbot test files in /tmp!!\n"
|
2019-04-26 15:07:07 +02:00
|
|
|
|
2021-01-05 11:40:28 +01:00
|
|
|
exit "${exitcode}"
|