You can contribute to the project in multiple ways:
- Write documentation
- Implement features
- Fix bugs
- Add unit and functional tests
- Everything else you can think of
This project uses :
- Poetry for building project :
- Install poetry :
pip install poetry
- Install dependencies :
poetry install
- Open a shell in project dédicated virtual env :
poetry shell
- Install poetry :
- Uvicorn server with live reload for development :
uvicorn --reload hookbridge.main:app
- FastAPI to expose HTTP REST API
- Dependency Injector for... dependency injection 😉
Before contributing, please make sure you have pre-commit installed and configured. This will help automate adhering to code style and commit message guidelines described below:
cd webhook-gateway/
pip3 install --user pre-commit
pre-commit install -t pre-commit -t commit-msg --install-hooks
Please provide your patches as GitHub pull requests. Thanks!
We enforce commit messages to be formatted using the conventional-changelog. This leads to more readable messages that are easy to follow when looking through the project history.
We use black as code formatter, so you'll need to format your changes using the
black code formatter. Pre-commit hooks will validate/format your code
when committing. You can then stage any changes black
added if the commit failed.
To format your code according to our guidelines before committing, run:
cd webhook-gateway/
pip3 install --user black
black .
We also use flake8 to ensure Python's PEP8 best practices are used.
cd webhook-gateway/
pip3 install --user flake8
flake8 .
Before submitting a pull request make sure that the tests and lint checks still succeed with your change. Unit tests run in GitHub Actions and passing checks are mandatory to get merge requests accepted.
An example can be found in tests/routes/test_rules.py
You need to install tox
(pip3 install tox
) to run tests locally:
# run unit tests for all supported python3 versions :
tox