These instructions assume that you have previously run the docker-compose command to start the local ecosystem and, therefore, that all migrations have been applied to the database. This also ensures that the default container network, ci_default, exists.
The docker-compose command used to run the full test suite sets environment variables. When running a subset of tests, you must ensure that you set the variables.
Build and test the "ci_test" Docker image by running this command:
docker compose -f ci/docker-compose-test.yml up
Rebuild ci_test whenever Dockerfile or poetry.lock changes.
There are two options for running ad hoc tests. Step 0 for either option is to stop all running containers other than the database.
- Start the Postgres (ci_db_1) container, if necessary:
docker start ci-db-1
. All migrations should already be applied. - Start a test container shell:
docker run --rm -it -v "$(pwd):/app" --env-file ci/.local.env --name ci-test --network ci_default test-notification-api bash
. Note the use of the environment file. - In the test container shell, run
pytest -h
to see the syntax for running tests. Without flags, you can runpytest [file or directory]...
.
- Edit
scripts/run_tests.sh
by commenting anypytest
execution and addingtail -f
to the end of the file - Run
docker compose -f ci/docker-compose-test.yml up
- In a separate window run
docker exec -it ci-test-1 bash
- Execute any command, such as
pytest --durations 10 tests/app/celery
This is an example of running a specific test in a test file from within a test container shell:
$ pytest tests/lambda_functions/va_profile/test_va_profile_integration.py::test_va_profile_cache_exists
Running Bash commands on a container with read-write access, such as ci_test, will result in the creation of .bash_history in your notification_api/ directory. That file is in .gitignore.
For a more interactive testing experience, edit scripts/run_tests.sh
so that it does not execute any pytest command, and place tail -f
on the final line e.g.
params="-rfe --disable-pytest-warnings --cov=app --cov-report=term-missing --junitxml=test_results.xml -q"
# pytest ${params} -n auto -m "not serial" tests/ && pytest ${params} -m "serial" tests/
display_result $? 2 "Unit tests"
tail -f
In a separate window execute:
docker exec -it ci-test-1 bash
This will allow exec into the ci-test-1
container, from which any desired bash commands may be executed. If you wish to also have visibility into the database, simply execute the following in a new window:
docker exec -it ci-db-1 bash
Then login to the test database with:
psql -U postgres -d notification_api
You can then execute psql commands.
The Github workflow also runs these tests when you push code. Instructions for running a subset of tests are located in tests/README.md.