- Thank you for your interest in contributing to the Communication Module of the Eclipse SCORE project!
- This guide will walk you through the necessary steps to get started with development, adhere to our standards, and successfully submit your contributions.
Before making any contributions, you must sign the Eclipse Contributor Agreement (ECA). This is a mandatory requirement for all contributors to Eclipse projects.
Sign the ECA here: https://www.eclipse.org/legal/ECA.php
Pull requests from contributors who have not signed the ECA will not be accepted.
To ensure a smooth contribution process, please follow the steps below:
- Fork the repository to your GitHub account.
- Create a feature branch from your fork:
git checkout -b feature/your-feature-name
- Write clean and modular code, adhering to:
- C++17 standard
- Google C++ Style Guide
- Add tests for any new functionality.
- Ensure all tests pass before submitting:
bazel test //... - Open a Pull Request from your feature branch to the
mainbranch of the upstream repository.- Provide a clear title and description of your changes.
- Reference any related issues.
- Bazel (Instructions for installing here: https://bazel.build/install)
- Docker (Instructions for installing here: https://docs.docker.com/engine/install/)
- Note. Running Docker in rootless mode is not yet officially supported but may work. See https://docs.docker.com/engine/security/rootless/ for more information.
We strive to be independent of the host platform via bazel sandboxing. Some host platforms come with limitations that bazel cannot sandbox sufficiently. For these platforms we collect instructions below.
Please be aware, that while we officially support Ubuntu 24.04 as the host platform that we also test in our CI. While other platforms generally should work, we can give no such guarantee. Should you face issues with your host platform, feel free to raise an issue or discussion where we will try to support.
Starting with Ubuntu 24.04 the security framework apparmor was introduced. The standard configuration of apparmor prohibits unprivileged user namespaces. This interferes with the bazel sandboxing mechanism and inhibits the linux-sandbox. Bazel falls back to a less powerful sandboxing mechanism that is insufficient for our project. This affects many bazel tests and potentially any bazel runnables.
To work around this issue, you can run the following bash script:
bash actions/unblock_user_namespace_for_linux_sandbox/action_callable.shNote. This must be rerun whenever the bazel version is updated.
To build and test the Communication Module, follow the steps below from the project root:
# Build all targets
bazel build //...
# Run all tests
bazel test //...For Linting the Code following solutions are available:
Copyright Checker:
# Check Sources
bazel run //:copyright.check
# Fix Sources
bazel run //:copyright.fixC++ and Bazel files formatter:
# Check Sources
bazel run //:format.check
# Fix Sources
bazel run //:formatThe Communication Module includes extensive tests. Use the following commands:
bazel test //...bazel test //score/mw/com/impl:all
bazel test //score/mw/com/message_passing:all- Unit Tests: Component-level testing
- Integration Tests: Cross-component interactions
- Performance Tests: Latency and throughput benchmarks
- Safety Tests: ASIL-B compliance verification
For project details, documentation, and support resources, please refer to the main README.md.
Thank you for contributing to the Eclipse SCORE Communication Module!