telegram-bot-bash/dev/all-tests.sh

80 lines
1.9 KiB
Bash
Raw Normal View History

2019-04-19 17:31:01 +02:00
#!/usr/bin/env bash
#############################################################
#
# 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
#############################################################
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
##########################
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
rm -f "${TESTENV}/botconfig.jssh" "${TESTENV}/botacl" 2>/dev/null
2020-12-04 21:35:21 +01:00
# mkdir needed dirs
mkdir "${TESTENV}/data-bot-bash"
# 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
[ "${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
###########################
# 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
#########################
# 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}"