This document describes how to easily set up your local dev environment to work on the StreamPipes Python client :snake:.
Create a virtual Python environment with a tool of your choice. As a next step, install all required dependencies for the development, e.g., with pip
:
pip install .[dev] # or alternatively: pip install .[all] to include dependencies for building the docs as well
In case you are on macOS and using zsh
the following should work for you:
pip install ."[dev]"
The pre-commit hook is run before every commit and takes care about code style, linting, type hints, import sorting, etc. It will stop your commit in case the changes do not apply the expected format. Always check to have the recent version of the pre-commit installed otherwise the CI build might fail:
pre-commit install
The definition of the pre-commit hook can be found in .pre-commit-config.yaml.
Below we list some conventions that we have agreed on for creating the StreamPipes Python client. Please comply to them when you plan to contribute to this project. If you have any other suggestions or would like to discuss them, we would be happy to hear from you on our mailing list dev@streampipes.apache.org.
Use numpy
style for Python docstrings :page_facing_up:
Please stick to the numpy
style when writing docstrings, as we require this for generating our documentation.
Provide tests :white_check_mark:
We are aiming for broad test coverage for the Python client and have therefore set a requirement of at least 90% unit test coverage. Therefore, please remember to write (unit) tests already during development. If you have problems with writing tests, don't hesitate to ask us for help directly in the PR or even before that via our mailing list (see above).