How to Contribute
We’d love to accept your patches and contributions to this project. There are just a few small guidelines you need to follow.
Ways of contributing
Contribution does not necessarily mean committing code to the repository. We recognize different levels of contributions as shown below in increasing order of dedication:
- Test and use the project. Give feedback on the user experience or suggest new features. 
- Report bugs or security vulnerability 
- Fix bugs. 
- Improve the project with developing new features. 
Filing bugs, security vulnerability or feature requests
You can file bugs against and feature requests for the project via github issues. Consult GitHub Help for more information on using github issues.
If you think you’ve found a potential vulnerability in this project, please email researchcenter@alliander.com to responsibly disclose it.
Community Guidelines
This project follows the following Code of Conduct.
REUSE Compliance & Source Code Headers
All the files in the repository need to be REUSE compliant. We use the pipeline to automatically check this. If there are files which are not complying, the pipeline will fail the pull request will be blocked.
This means that every file containing source code must include copyright and license information. This includes any JS/CSS files that you might be serving out to browsers. (This is to help well-intentioned people avoid accidental copying that doesn’t comply with the license.)
Apache 2.0 header:
SPDX-FileCopyrightText: Alliander N. V.
SPDX-License-Identifier: Apache-2.0
Git branching
This project uses feature branches. The main branch always contains the latest stable version, new features are developed in individual branches using a descriptive name. When a feature is finished it is merged back into main. These releases will happen in unplanned intervals, whenever a new feature is ready.
Signing the Developer Certificate of Origin (DCO)
This project utilize a Developer Certificate of Origin (DCO) to ensure that each commit was written by the author or that the author has the appropriate rights necessary to contribute the change. Specifically, we utilize Developer Certificate of Origin, Version 1.1, which is the same mechanism that the Linux® Kernel and many other communities use to manage code contributions. The DCO is considered one of the simplest tools for sign-offs from contributors as the representations are meant to be easy to read and indicating signoff is done as a part of the commit message.
This means that each commit must include a DCO which looks like this:
Signed-off-by: Joe Smith <joe.smith@email.com>
The project requires that the name used is your real name and the e-mail used is your real e-mail. Neither anonymous contributors nor those utilizing pseudonyms will be accepted.
There are other great tools out there to manage DCO signoffs for developers to make it much easier to do signoffs:
- Git makes it easy to add this line to your commit messages. Make sure the - user.nameand- user.emailare set in your git configs. Use- -sor- --signoffto add the Signed-off-by line to the end of the commit message.
- Github UI automatic signoff capabilities for adding the signoff automatically to commits made with the GitHub browser UI. This one can only be activated by the github org or repo admin. 
- GitHub UI automatic signoff capabilities via custom plugin for adding the signoff automatically to commits made with the GitHub browser UI 
- Additionally, it is possible to use shell scripting to automatically apply the sign-off. For an example for bash to be put into a .bashrc file, see here. 
- Alternatively, you can add - prepare-commit-msg hookin .git/hooks directory. For an example, see here.
Code reviews
All patches and contributions, including patches and contributions by project members, require review by one of the maintainers of the project. We use GitHub pull requests for this purpose. Consult GitHub Help for more information on using pull requests.
Pull Request Process
Contributions should be submitted as Github pull requests. See Creating a pull request if you’re unfamiliar with this concept.
The process for a code change and pull request you should follow:
- Create a topic branch in your local repository, using a decriptive name. For more information see the Git branching guideline. 
- Make changes, compile, and test thoroughly. Ensure any install or build dependencies are removed before the end of the layer when doing a build. Code style should match existing style and conventions, and changes should be focused on the topic the pull request will be addressed. For more information see the style guide. 
- Push commits to your fork. 
- Create a Github pull request from your topic branch. 
- Pull requests will be reviewed by one of the maintainers who may discuss, offer constructive feedback, request changes, or approve the work. For more information see the Code review guideline. 
- Upon receiving the sign-off of one of the maintainers you may merge your changes, or if you do not have permission to do that, you may request a maintainer to merge it for you. 
Testing Guidelines
This project uses pytest together with launch_pytest for integration and end-to-end testing.
Test packages can contain:
- unit/: for pure logic tests
- integration/: for ROS service or component interactions
- end_to_end/: for full-stack functional tests
Tests are configured to support two modes:
- Simulation (default): Tests run in a simulated environment using the same launch and control setup as the real robot. This is useful for fast feedback during development without needing access to hardware. 
- Real Hardware: Tests run on the actual robot if it’s available and properly set up. We expect most things to behave the same as in simulation, but it’s still important to test on the real hardware to catch timing issues, integration problems, or hardware-specific problems. Make sure everything is running and safe before starting. 
You can switch between these modes using the --simulation option:
# Run tests in simulation mode (default)
pytest
# Run tests on real hardware
pytest --simulation=False
Attribution
This Contributing.md is adapted from Google available at https://github.com/google/new-project/blob/master/docs/contributing.md