icwmp/gitlab-ci/functional-test.sh
2022-07-13 08:44:18 +05:30

89 lines
2.2 KiB
Bash
Executable file

#!/bin/bash
echo "preparation script"
pwd
. ./gitlab-ci/shared.sh
. ./test/script/common.sh
trap cleanup EXIT
trap cleanup SIGINT
date +%s > timestamp.log
echo "Compiling icmwp"
build_icwmp
echo "Starting dependent services"
supervisorctl status all
supervisorctl update
supervisorctl restart all
supervisorctl stop icwmpd
supervisorctl status all
echo "Configuring genieacs"
configure_genieacs
mkdir -p /var/state/icwmpd
echo "Starting icwmpd deamon"
supervisorctl start icwmpd
sleep 5
echo "Checking cwmp status"
check_cwmp_status
[ -f funl-test-result.log ] && rm -f funl-test-result.log
sleep 10
echo "## Running script verification of functionalities ##"
echo > ./funl-test-result.log
echo > ./funl-test-debug.log
test_num=0
for test in $(ls -I "common.sh" -I "verify_custom_notifications.sh" test/script/); do
ret=0
test_num=$(( test_num + 1 ))
echo "#### Start $test ####" >> "$icwmp_master_log"
if ./test/script/"${test}"; then
echo "ok ${test_num} - ${test}" >> ./funl-test-result.log
remove_icwmp_log
echo "#### $test Done ####" >> "$icwmp_master_log"
else
echo "not ok ${test_num} - ${test}" >> ./funl-test-result.log
remove_icwmp_log
echo "#### $test Ended with error ####" >> "$icwmp_master_log"
ret=1
fi
echo "########### $test result $ret ##########"
done
echo "Stop all services"
supervisorctl stop icwmpd
echo "Verify Custom notifications"
echo "#### Start custom_notifications ####" >> "$icwmp_master_log"
if ./test/script/verify_custom_notifications.sh; then
echo "ok - verify_custom_notifications" >> ./funl-test-result.log
remove_icwmp_log
echo "#### Done custom_notifications ####" >> "$icwmp_master_log"
else
echo "not ok - verify_custom_notifications" >> ./funl-test-result.log
remove_icwmp_log
echo "#### custom_notifications ended with error ####" >> "$icwmp_master_log"
fi
test_num=$(( test_num + 1 ))
echo "1..${test_num}" >> ./funl-test-result.log
# Artefact
gcovr -r . 2> /dev/null --xml -o ./funl-test-coverage.xml
#GitLab-CI output
gcovr -r . 2> /dev/null
cp ./memory-report.xml ./funl-test-memory-report.xml
#report part
exec_cmd tap-junit --input ./funl-test-result.log --output report
check_valgrind_xml
echo "Functional test :: PASS"