virtool is a web-based application for diagnosing pathogen infections using high-throughput sequencing.
Website: https://www.virtool.ca
See the virtool documentation to get started with the latest version of virtool 4.0.0.
virtool is currently undergoing a major transformation into a cloud-native application. This will mean virtool can scale work across multiple hosts and run natively in Kubernetes and public cloud providers.
For current users and administrators:
In the source directory root:
Start the required backing services in Docker.
docker compose -f tests/docker-compose.yml -p virtool-test up -d
Run the test suite:
poetry run pytest
The test suite works with pytest-xdist
.
poetry run pytest -n 4
This will use multiple Python processes to run the tests in parallel.
We use Syrupy for snapshot testing.
Snapshots are used for tests where we want to assert that an object (eg. database record, Pydantic object, API response) has an expected shape and set of values.
If snapshots need to be updated:
poetry run pytest <path_to_test_file> --su
You can be even more specific by specifying the test class or function:
poetry run pytest <path_to_test_file>::<class_or_function>
Always be specific about what snapshots you are updating. Don't blindly update a ton of snapshot files just to make your tests pass.
All commits must follow the Conventional Commits specification.
These standardized commit messages are used to automatically publish releases using semantic-release
after commits are merged to main
from successful PRs.
Example
feat: add API support for assigning labels to existing samples
Descriptive bodies and footers are required where necessary to describe the impact of the commit. Use bullets where appropriate.
Additional Requirements
From Tim Pope: A Note About Git Commit Messages