Running ruleset unit and integration tests
Various components of Yoda have unit and integration tests. They run automatically using Github Actions. This page explains how to run them locally.
Running ruleset unit tests
The ruleset uses the unittest framework for the unit tests.
The test suites can be found in the unit-tests
subdirectory of the ruleset. Example commands for running them
manually:
$ python -m venv venv
$ source venv/bin/activate
$ python -m pip install --upgrade pip
$ python -m pip install -r requirements.txt
$ cd unit-tests
$ export PYTHONPATH=$(cd ../util ; pwd):$PYTHONPATH
$ python -m unittest unit_tests
..............................................................
----------------------------------------------------------------------
Ran 62 tests in 0.009s
OK
Running ruleset integration tests
The ruleset has a custom rule for running the integration tests. These tests verify that various functions work in combination with iRODS. You need to run the tests on either the Docker setup or on a development VM that has the test dataset. Please consult the API and UI tests manual page for instructions on how to install test data on a development VM.
You can then run the integration tests from the irods
account using the integration test script.
$ /etc/irods/yoda-ruleset/tools/run-integration-tests.sh
[... output omitted]
util.collection.exists.yes VERDICT_OK
util.collection.exists.no VERDICT_OK
util.collection.owner VERDICT_OK
util.collection.to_from_id VERDICT_OK
util.data_object.exists.yes VERDICT_OK
util.data_object.exists.no VERDICT_OK
util.data_object.owner VERDICT_OK
util.data_object.size VERDICT_OK
[... output omitted]
In order to run only a single test, add the test name as a parameter, like this:
$ /etc/irods/yoda-ruleset/tools/run-integration-tests.sh util.collection.owner
util.collection.owner VERDICT_OK
In order to run all integration tests with a particular prefix, add a * after the prefix. For example:
$ /etc/irods/yoda-ruleset/tools/run-integration-tests.sh util.collection.*
util.collection.exists.yes VERDICT_OK
util.collection.exists.no VERDICT_OK
util.collection.owner VERDICT_OK
util.collection.to_from_id VERDICT_OK
Running Yoda portal unit tests
The Yoda portal uses the unittest framework for the unit tests.
The test suites can be found in the unit-tests
subdirectory of the portal repository. Run them using Python 3:
$ cd unit-tests
$ python3 -m unittest
......
----------------------------------------------------------------------
Ran 6 tests in 0.001s
OK
Running external user service unit and integration tests
The external user service (EUS) uses pytest for unit and integration tests.
In order to run them, install the EUS package in a Python 3 virtual environment,
go to yoda_eus/tests
and run the test suites using pytest
. Example:
(venv) $ cd yoda_eus/tests
(venv) $ python3 -m pytest
===================================================================================== test session starts ======================================================================================
platform linux -- Python 3.10.12, pytest-7.4.2, pluggy-1.3.0
rootdir: /data/source/yoda-external-user-service
collected 33 items
test_integration.py ....................... [ 69%]
test_unit.py .......... [100%]
===================================================================================== 33 passed in 10.02s ======================================================================================
Running MOAI unit and integration tests
MOAI uses the unittest framework for the unit and integration tests.
In order to run them you need to install apxs (sudo apt install apache2-dev
on Ubuntu)
and SQLite3 libraries (sudo apt install libsqlite3-dev
on Ubuntu). Then install MOAI in a Python 3 virtual environment
and run the tests using unittest
:
(venv) $ cd moai
(venv) $ python3 -m unittest
......................
----------------------------------------------------------------------
Ran 22 tests in 0.192s
OK