You can get a high-level glimpse on how the different components interact in the diagram below. That should make it easier to navigate the codebase. Please refer to the in-line code documentation for more information.
You can open and edit the architecture.drawio file on diagrams.net.
- Fork the repository
- Create a feature or bugfix branch from
dev
- Push your changes to the branch on your forked repository
- Submit a PR towards
dev
branch of this repository.
Note: It's important to base your work on top of the
dev
branch. Themain
branch will only be updated once a new release is ready to be pushed. I'll then be merging all changes fromdev
intomain
.
Please use short and descriptive titles and expand on the "why" inside the body of the commit message if necessary. In this repository we use the imperative form. For more information on good commit messages, I recommend the following article:
Before submitting a PR make sure that your feature is covered with tests.
- Install dependencies for auto-formatting and linting:
pip3 install black flake8 mypy
pip3 install types-PyYAML types-python-dateutil types-paramiko types-retry
- Run formatting, type checking and linting:
black src tests && mypy src tests && flake8 src tests
- Run tests:
PUSHOVER_API_TOKEN=<your_token> PUSHOVER_USER_KEY=<your_key> TELEGRAM_BOT_TOKEN=<your_token> TELEGRAM_CHAT_ID=<your_chat_id> python3 -m unittest
Check that all passes and there aren't any warnings.
If you did not modify any logic in one of the notifiers, you can skip these tests and run all others without specifying any tokens:
python3 -m unittest
Most importantly: Have fun and if you're unsure about some contribution, don't shy away from submit a Pull Request anyway. We can use that as a basis for discussions, provide feedback and iterate on further improvements. Cheers!