The integration tests use the Bats framework. Bats is a TAP-compliant testing framework for Bash. It provides a simple way to verify that the UNIX programs you write behave as expected.
- $REPO_DIR - the folder where the tests repo was cloned.
- The tests are located in
$REPO_DIR/bats/tests
. - List of the Bats dependencies used in the tests:
Bats lib | path | repository |
---|---|---|
bats-core | bats/lib/bats | https://github.com/bats-core/bats-core.git |
bats-support | bats/lib/test_helper/bats-support | https://github.com/bats-core/bats-support.git |
bats-assert | bats/lib/test_helper/bats-assert | https://github.com/bats-core/bats-assert.git |
- Supported platforms: Linux (x86), macOs (x86, m1), windows (WSL)
- Linter (github actions): ShellCheck/Shell Linter
Fetch the repository with the dependencies (the submodules are necessary to successfully execute the tests):
git clone --recurse-submodules https://github.com/pyrsia/pyrsia-integration-tests.git
In case you forgot to set --recurse-submodules
during clone
you can run the following command for the same effect:
git submodule update --init
Prerequisite:
- Ensure that docker daemon is running and JQ is installed.
- Ensure the pyrsia config contains the values shown below (show pyrsia config -
pyrsia config --show
):
host = 'localhost'
port = '7888'
disk_allocated = '10 GB'
Run the tests:
REPO_DIR=<path to your integration tests repo> $REPO_DIR/bats/run_tests.sh
To run tests on your branch you should define variables:
GIT_REPO=<git repository URL>
, default value:https://github.com/pyrsia/pyrsia.git
GIT_BRANCH=<branch repository name>
, default value:main
For example, to run tests from the folder with cloned pyrsia-integration-tests
repo, you can use following command:
GIT_REPO=<your forked pyrsia repo url> \
GIT_BRANCH=<branch name to test> \
TEST_LOG_LEVEL=debug \
REPO_DIR=. \
./bats/run_tests.sh
- Pyrsia CLI/connectivity related tests
- Test 'pyrsia help' CLI, check if the help is shown.
- Test 'pyrsia ping' CLI, check if the node is up and reachable.
- Test 'pyrsia status' CLI, check if the node is connected to peers.
- Test 'pyrsia list' CLI, check if the node returns the list of peers.
- Test 'pyrsia config' CLI, check if the config can be changed with valid values and shown.
- Test 'pyrsia version' CLI, check if the CLI version shows.
- Test 'pyrsia build' help options CLI, check if the build help is shown.
- Test 'pyrsia inspect-log' help/options CLI, check if the inspect-log help is shown.
- Test 'pyrsia authorize' help/options CLI, check if the authorize help is shown.
- Pyrsia build service
- Test the build service, MAVEN (build, inspect-log) (DISABLED)
- Test the build service, DOCKER (build docker image, inspect-log).
The docker containers and images created by the tests framework are removed when CLEAN_UP_TEST_ENVIRONMENT=true (default).
The docker images and containers have to be removed manually if CLEAN_UP_TEST_ENVIRONMENT=false. The Pyrsia integration
tests also create the temp directory /tmp/pyrsia_tests
which is not removed by the tests framework and if necessary has to be removed
manually.
Note: CLEAN_UP_TEST_ENVIRONMENT=false
is not recommended because it impacts the tests environment and can lead to random failures.
In case of any problems with the tests environment reset the environment as follows:
- Remove all docker images and containers:
docker system prune --all
- Remove the integration tests temp directory:
rm -rf /tmp/pyrsia_tests/
Supported logging levels:
- INFO (default)
- DEBUG
- ERROR
How to use logger in the tests:
# load the test from the library
load '../lib/logger/load'
# print logging messages
log INFO "Info test message!"
log DEBUG "Debug test message!"
log ERROR "Error test message!"
How to start the tests with a different logging level (e.g DEBUG):
TEST_LOG_LEVEL=<log level e.g DEBUG> REPO_DIR=<path to your integration tests repo> $REPO_DIR/bats/run_tests.sh