Contributing Guidelines
Welcome to Shipwright, we are glad you want to contribute to the project! This document contains general guidelines for submitting contributions. Each component of Shipwright will have its own specific guidelines.
Contributing prerequisites (CLA/DCO)
The project enforces Developer Certificate of Origin (DCO). By submitting pull requests submitters acknowledge they grant the Apache License v2 to the code and that they are eligible to grant this license for all commits submitted in their pull requests.
Getting Started
All contributors must abide by our Code of Conduct.
The core code for Shipwright is located in the following repositories:
- build - the Build APIs and associated controller to run builds.
- cli - the
shp
command line for Shipwright builds - operator - an operator to install Shipwright components on Kubernetes via OLM.
Technical documentation is spread across the code repositories, and is consolidated in the website repository.
Content in website
is published to shipwright.io
Creating new Issues
We recommend to open an issue for the following scenarios:
- Asking for help or questions. (Use the discussion or help_wanted label)
- Reporting a bug. (Use the kind/bug label)
- Requesting a new feature. (Use the kind/feature label)
Use the following checklist to determine where you should create an issue:
- If the issue is related to how a Build or BuildRun behaves, or related to Build strategies, create an issue in build.
- If the issue is related to the command line, create an issue in cli.
- If the issue is related to how the operator installs Shipwright on a cluster, create an issue in operator.
- If the issue is related to the shipwright.io website, create an issue in website.
If you are not sure, create an issue in this repository, and the Shipwright maintainers will route it to the correct location.
If feature request is sufficiently broad or significant, the community may ask you to submit a SHIP enhancement proposal. Please refer to the SHIP guidelines to learn how to submit a SHIP proposal.
Writing Pull Requests
Contributions can be submitted by creating a pull request on Github. We recommend you do the following to ensure the maintainers can collaborate on your contribution:
- Fork the project into your personal Github account
- Create a new feature branch for your contribution
- Make your changes
- If you make code changes, ensure tests are passing
- Open a PR with a clear description, completing the pull request template if one is provided Please reference the appropriate GitHub issue if your pull request provides a fix.
NOTE: All commits must be signed-off (Developer Certificate of Origin (DCO)) so make sure you use the -s
flag when you commit. See more information on signing in here.
Code review process
Once your pull request is submitted, a Shipwright maintainer should be assigned to review your changes.
The code review should cover:
- Ensure all related tests (unit, integration and e2e) are passing.
- Ensure the code style is compliant with the coding conventions
- Ensure the code is properly documented, e.g. enough comments where needed.
- Ensure the code is adding the necessary test cases (unit, integration or e2e) if needed.
Contributors are expected to respond to feedback from reviewers in a constructive manner. Reviewers are expected to respond to new submissions in a timely fashion, with clear language if changes are requested.
Once the pull request is approved and marked “lgtm”, it will get merged.
Community Meetings Participation
Shipwright Community Meetings take place weekly on Monday’s at 13:00 UTC time.
In our Public Calendar you will find all weekly meetings. Meetings are hosted in Zoom and are Public.
You can register yourself via the Public Calendar as well.
The Zoom Meeting comes with information about the Agenda to discuss.
Contact Information
- Slack channel
- End-user email list: shipwright-users@lists.shipwright.io
- Developer email list: shipwright-dev@lists.shipwright.io
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.