Thank you for considering contributing to the AutoCare REST API ! By participating, you're helping to build a more reliable and feature-rich community project. Please take a moment to review these guidelines to ensure a smooth collaboration.
- Getting Started
- Reporting Issues
- Suggesting Features
- Submitting Pull Requests
- Code Quality and Maintenance
- Testing
- Documentation
- Licensing
- Fork this repository, then clone your fork to your local machine
- Set up the project by following the instructions in the README file (check Technology Stack and Getting Started sections)
- Ensure that the project builds successfully by running
./mvnw clean install
.
REMINDER: If you'd like to have a friendly-chat assistance, feel free to join us on Together Java Discord server. We have a dedicated channel made specially to collaborate on this project!
If you encounter a bug, please open an issue and provide enough details.
- Describe the problem and your environment (OS, Browser, IDE etc.).
- Provide the steps to reproduce the issue.
- Show any relevant logs or stack traces you have.
- Add notes, screenshots or attachments if needed.
Feature suggestions are welcome! Before you start working on a new feature :
- Open an issue to discuss your idea.
- Provide a clear and concise description of the feature.
- Outline the benefits and potential drawbacks.
When you're ready to submit your changes:
- Ensure your code adheres to the project's Code Style.
- Write or update tests to cover your changes.
- Document your changes where necessary.
- Push your changes to a branch in your forked repository.
- Open a pull request (PR) to the main repository's
main
branch.
When submitting a PR, please:
- Link to the relevant issue (if possible).
- Provide a brief description of what your PR does.
- Ensure all tests pass by running
mvn verify
. - Keep your PR small and focused: avoid combining unrelated changes.
To maintain a consistent code style and ensure high code quality, we have integrated several tools and practices into our project:
-
Spotless: Ensures that the code adheres to defined formatting rules. Spotless helps keep the codebase clean and uniformly formatted.
-
Checkstyle: Assists in writing code that conforms to Java standard coding practices. It enforces a set of coding standards and helps maintain good quality.
Note: If you're new to these tools, there’s no need to worry. They are already configured and will work seamlessly in the background.
To ensure code quality and proper branching, we use Git hooks managed by the Git Build Hook Maven Plugin. This plugin facilitates the management of hook scripts (check ./configs/git-hooks/pre-commit
file).
This technique helps prevent poorly formatted or non-compliant code from being committed or pushed.
Currently, there are 2 sorts of hooks :
-
Pre-commit: Automatically format code and run checks before allowing a commit. If issues are found, the commit will be aborted until the issues are resolved.
-
Pre-push: (check the next section)
To maintain clarity and consistency, we follow a structured branch naming convention. A pre-push Git hook is in place to enforce this convention (check ./configs/git-hooks/pre-push
file).
Serious bug fixes or improvements must be accompanied by tests to ensure that new features or fixes do not break existing functionality.
Ensure that your tests pass by running mvn test
.
Clear documentation is crucial for the project’s usability:
- Update the README file if your changes affect the setup or usage of the project.
- Add Javadoc comments to all public classes and methods.
- If your contribution requires significant details, create or update relevant markdown file(s) in the /docs directory.
By contributing to this project, you agree that your contributions will be licensed under the GNU Affero General Public License (AGPL). Check the LICENSE file for more details.