The functional test suite for Orion-LD, found in the Orion-LD repository, under test/functionalTests
, needs some installation in order to work.
First of all, there is a python script (scripts/accumulator-server.py
) that is used as the receptor of the notifications during the functional tests.
This python script needs a few packages to be installed:
- Install OpenSSL for Python:
sudo aptitude install python-openssl
- Install Flask:
sudo aptitude install python3-venv
pip install Flask
- Install virtualenv:
sudo aptitude install virtualenv
The test script (test/functionalTest/testHarness.sh
) needs to find the accumulator, in order to start it:
cd ~/git/context.Orion-LD
export PATH=$PATH:$PWD/scripts
which accumulator-server.py
The output of the which
command should be:
~/git/context.Orion-LD/scripts/accumulator-server.py
Also, the test script uses nc
(netcat) to verify that the broker has started, and bc
for simple calculations.
Install both of them:
sudo aptitude install netcat
sudo aptitude install bc
Test it by launching:
test/functionalTest/testHarness.sh
Lastly, some of the functional tests uses a Context Server, developed also by the FIWARE Foundation (Stefan Wiedemann). It runs in a docker container:
docker run --rm -d --name context-server -p 7080:8080 -e MEMORY_ENABLED=true wistefan/context-server
timeout 30 bash -c 'while [[ "$(curl -s -o /dev/null -w ''%{http_code}'' http://localhost:7080/health)" != "200" ]]; do sleep 5; done' || false
There are over 1700 test cases (each with a number of steps), so, it will take a while (90+ minutes, depending on your hardware).
Orion-LD has inherited the functional test suite from orion
and added some 600 test cases only for NGSI-LD.
If you want to run only the NGSi-LD test cases, run the suite with the -ld
option:
test/functionalTest/testHarness.sh -ld
There are lots of command line options for the test suite; use the -u
option to see all of them.
In case some functional test case fails, normally due to installation error, and you're not really interested in that case (might be for IPv6 and you aren't interested in IPv6), you can disable test cases.
Functional test cases can be disabled by exporting an environment variable called CB_SKIP_FUNC_TESTS
.
For example, to disable the test case 'direct_https_notifications.test' (you don't want https notification, so ...), do this:
export CB_SKIP_FUNC_TESTS=0706_direct_https_notifications/direct_https_notifications.test
Note that not only the name of the test case file, but also the directoy where it resides is part of the "identifier". This is so because different functional test case directories can have test case files with the same name.
FYI: after following myself the instructions in the installation guides, the following functional tests failed for me:
- 0706_direct_https_notifications/direct_https_notifications.test
- 0706_direct_https_notifications/direct_https_notifications_no_accept_selfsigned.test
Hmmm, something about https seems to be missing in the instructions ...
Looking closer at the errors, it seems clear that it is the accumulator script that is having problems (the accumulator log-file says: AttributeError: 'Context' object has no attribute 'wrap_socket'). I will have to look into this, but for now, I simply do this:
export CB_SKIP_FUNC_TESTS="0706_direct_https_notifications/direct_https_notifications.test 0706_direct_https_notifications/direct_https_notifications_no_accept_selfsigned.test"
Remember to put this environment variable in your startup files (e.g. ~/.bash_profile
), so that you don't lose it.
Also, the directory added to PATH should be saved in your startup files.