Contributing to this project should be as easy and transparent as possible, whether it's:
- Reporting a bug
- Discussing the current state of the code
- Submitting a fix
- Proposing new features
Github is used to host code, to track issues and feature requests, as well as accept pull requests.
Pull requests are the best way to propose changes to the codebase.
- Fork the repo and create your branch from
main
. - If you've changed something, update the documentation.
- Make sure your code lints (using
scripts/lint
). - Test you contribution.
- Issue that pull request!
This repository is built around the developer working in VS Code. It features a devcontainer to ensure a consistent development environment for anyone working on the repository.
This devcontainer makes use of a Docker container, which means you will need Docker running on your machine as well.
Of course, you're free to develop in any environment you want but the standards at pull request are enforced around development in VS Code.
Follow the official Home Assistant instructions for developers: Set up Development Environment
In short, when you submit code changes, your submissions are understood to be under the same MIT License that covers the project. Feel free to contact the maintainers if that's a concern.
Report bugs using Github's issues
GitHub issues are used to track public bugs. Report a bug by opening a new issue; it's that easy!
Great Bug Reports tend to have:
- A quick summary and/or background
- Steps to reproduce
- Be specific!
- Give sample code if you can.
- What you expected would happen
- What actually happens
- Notes (possibly including why you think this might be happening, or stuff you tried that didn't work)
People love thorough bug reports. I'm not even kidding.
Use black to make sure the code follows the style.
This custom component is based on integration_blueprint template.
It comes with development environment in a container, easy to launch
if you use Visual Studio Code. With this container you will have a stand alone
Home Assistant instance running and already configured with the included
configuration.yaml
file.
Debugging is done using the Remote Python Debugger.
Enable it by commenting on the relevant lines in
configuration.yaml
.
With this configuration Home Assistant will pause on start up, waiting for the debugger to attach. You can do this by pressing F5 or going to the 'Run and Debug' tab on the left.
By contributing, you agree that your contributions will be licensed under its MIT License.