Skip to content

Contributing

Packaging and Installation

This project uses poetry for packaging and dependency management. So before you can start developing you will have to install poetry. Please refer to the poetry documentation on how to install and use poetry.

After you have installed poetry you can use it to install a local development clone of the repository using:

$ poetry install

Tests can be run using poetry or by using the Makefile provided with the project.

$ poetry run pytest
$ make test
# or if you wish to generate a HTML coverage report
$ make test-html

Code Quality and Formatting

This project uses pre-commit and various code linters and formatters to ensure that committed code meets certain quality criteria. Note that these criteria are also checked by CI pipelines. This means that should you push unchecked code the pipelines will fail! So it is highly recommend that you install pre-commit so that such code does not make it into the the git history.

To make sure that you don't accidentally commit code that does not follow the coding style, you can install a pre-commit hook that will check that everything is in order:

$ poetry run pre-commit install

The pre-commit git hook runs automatically when you try to commit your changes. It will automatically check and try to format your code. Should your code not conform to the quality criteria or if some re-formatting was necessary the commit will fail. In such cases verify the formatting changes made by pre-commit and fix any other code quality issues reported by the checks before committing your changes again.

You can also manually run the pre-commit hook by issuing the following command.

$ poetry run pre-commit run --all-files

Alternatively you can also use the Makefile to run just the quality checks, auto formatting or just specific checks.

$ make check
$ make format

Run make list for a full list of available make targets.

Testing & Code Coverage

New code should also always be covered by corresponding tests. Please ensure that all your code is sufficiently covered existing or new tests. Should your MR decrease code coverage significantly or cause any tests to fail it will not be merged.

You can check the code coverage of your code in your IDE if it supports reading coverage.xml files or by creating and inspecting a HTML coverage report.

$ make test-html

The HTML coverage report is created in htmlcov and can be navigated by opening the index.html file.

Build & View Documentation

This project uses MkDocs for documentation. If you wish to view or edit the docs you can start a live server by running:

$ mkdocs serve

The live server will automatically detect changes and refresh the documentation.

We also provide convenience make targets for building the documentation and starting the live server:

# build the distributable documentation site
$ make docs
# build a offline viewable documentation site, without web server simply open the index file
# (Note that the search function is disabled with this)
$ make docs-offline
# start the mkdocs live server
$ make docs-serve