Contributing to dōteki
Thanks for contributing to dōteki. Before implementing new features and changes, please submit an issue so that we can discuss it.
We welcome contributions in many forms, including:
- Bug reports
- Bug fixes
- Plugin suggestions
- New plugins
- Improvements to the codebase
- Documentation improvements
If you're not sure how to contribute or need help with something, please don't hesitate to reach out via the issue tracker or email.
Coding guidelines
- Use
black
to format your code before submitting a pull request. - Functions should be type annotated. Use
mypy
to check for type errors. - Keep the code clean and maintainable. Here are some guidelines:
Click to expand guidelines
-
Test coverage: Ensure comprehensive code coverage and keep tests readable. 80% coverage is the minimum; 100% is nice to have.
-
Short, focused functions: Keep functions brief and adhere to a single responsibility. Minimise arguments and make function signatures intuitive.
-
Descriptive naming: Use unambiguous names to clarify function and variable purpose.
-
Consistent level: Maintain one level of abstraction or focus within functions.
-
DRY: Don't Repeat Yourself; abstract repeated code into functions.
-
Error handling: Use logging and provide clear, actionable error messages.
-
Minimal comments: Keep code self-explanatory. Explain the why, not the how.
-
Early returns: Avoid deep nesting.
Further reading
Pull Requests
Working on your first Pull Request? You can learn how from this free video series:
How to Contribute to an Open Source Project on GitHub
Please make sure the following is done when submitting a pull request:
- Keep your PR small. Small pull requests are much easier to review and more likely to get merged. Make sure the PR does only one thing, otherwise please split it.
- Use descriptive titles. It is recommended to follow this commit message style.
- Test your changes. Make sure to include tests that cover your changes.
- Fill the PR template. The template will guide you through the process of submitting a PR.
Our integration systems run automated tests to guard against mistakes. To speed things up, make sure you have done the following before submitting your PR:
- Make sure all new and existing tests pass with
poetry run pytest
. - Run
poetry run mypy doteki
to check for type errors. - Run
poetry run black {file/dir}
to format your code. - If necessary, update the documentation (in
website/docs/
).
You might find the hooks in .githooks/
useful. To use them, run git config core.hooksPath .githooks
.
Conventional Commit Messages with Gitmoji
See how a minor change to your commit message style can make you a better programmer.
Format: <gitmoji> <type>(<scope>): <description>
<gitmoji>
is an emoji from the gitmoji list. It makes it easier to visually scan the commit history and quickly grasp the purpose of changes.
<scope>
is optional. If your change affects a specific part of the codebase, consider adding the scope. Scopes should be brief but recognizable, e.g. config
, gitmoji
, or cli
.
The various types of commits:
feat
: a new API or behavior for the end user.fix
: a bug fix for the end user.docs
: a change to the website or other Markdown documents.refactor
: a change to code that doesn't change behavior, e.g. splitting files, renaming internal variables, improving code style…test
: adding missing tests, refactoring tests; no production code change.chore
: upgrading dependencies, releasing new versions… Chores that are regularly done for maintenance purposes.misc
: anything else that doesn't change production code, yet is nottest
orchore
. e.g. updating GitHub actions workflow.
The commits within your PR don't need to follow this convention (we'll squash them). However, the PR title should be in this format. If you're not sure about the title, don't worry, we'll help you fix it. Your code is more important than conventions!
Example:
✨ feat(feed): allow custom date format
^ ^--^^----^ ^----------------------^
| | | |
| | | +-> Description in imperative and lowercase.
| | |
| | +-> The scope of the change.
| |
| +-------> Type: see above for the list we use.
|
+----------> A valid gitmoji.
Code of conduct
We expect all contributors to follow our Code of Conduct. Please be respectful and professional when interacting with other contributors.
Thank you for your contributions!