The purpose of this document is to give guidance to the Kyma contributors. All the rules are listed and explained here, and all contributors and maintainers must follow them.
To learn how to name objects in this project, see the naming document.
The main README.md
document in the templates
subfolder in this repository contains an overview of document templates used in specific Kyma repositories. The templates themselves are collected in the resources
subfolder.
Extend the list whenever you define a new template for other document types. Make sure to update the table in the README.md
document after you add new templates to the resources
subfolder.
Read the subsections to learn the details of the agreements to submit and licences to comply with as a Kyma contributor.
As a Kyma contributor, you must accept the Kyma project's licenses and submit the Individual Contributor License Agreement before you contribute code or content to any Kyma repository. Kyma maintainers will not accept contributions made without such consent. This applies to all contributors, including those contributing on behalf of a company. If you agree to the content of the Agreement, click the link posted by the CLA assistant as a comment to the pull request (PR). The CLA assistant saves your decision for future contributions and notifies you if there is any change to the CLA in the meantime.
Employees of a company who contribute code need to submit one company agreement in addition to the individual agreement above. This is mainly for the protection of the contributing employees.
An authorized company representative needs to download, fill in, and print the Corporate Contributor License Agreement form. Scan it and send it to info@kyma-project.io. The form contains a list of employees who are authorized to contribute on behalf of your company. To report any changes on the list, contact info@kyma-project.io.
If you are a contributor, follow these basic rules:
- The contribution workflow in all Kyma repositories bases on the principles of the GitHub Flow. Thus, the
master
branch is the most important one. Avoid working directly on it. When you work on new features or bug fixes, work on separate branches. - Work on forks of Kyma repositories.
- You can merge a PR if you receive an approval from at least one code owner from each part of the repository to which you contribute in your PR.
Every contributor commits to the following agreement:
- In every PR, include a description or a reference to a detailed description of the steps that the maintainer goes through to check if a PR works and does not break any other functionality.
- Provide clear and descriptive commit messages.
- Label your PRs.
- Follow the accepted documentation rules and use appropriate templates.
- As the creator of the PR, you are responsible for ensuring that the PR follows the correct review and approval flow.
This section explains how you can contribute code or content to any Kyma repository, propose an improvement, or report a bug. The contributing process applies both to the members of the Kyma organization and the external contributors.
To contribute code or content to a given Kyma repository, follow these steps:
- Make sure that the change is valid and approved. If you are an external contributor, open a GitHub issue before you make a contribution.
- Fork the Kyma repository that you want to contribute to.
- Clone it locally, add a remote upstream repository for the original repository, and set up the
master
branch to track the remotemaster
branch from the upstream repository. See the git-workflow document to learn how to configure your fork. - Create a new branch out of the local
master
branch of the forked repository. - Commit and push changes to your new branch. Create a clear and descriptive commit message in which you specify what you have changed. See the
git-workflow.md
document for commit message guidelines. - Create a PR from your branch on the forked repository to the
master
branch of the original, upstream repository. Fill in the PR template according to instructions. - Read and accept the Contributor Licence Agreement (CLA).
- If there are merge conflicts on your PR, squash your commits and rebase the
master
branch. - In your PR:
- Provide a reference to any related GitHub issue.
- Make sure that the Allow edits from maintainers option is selected to allow upstream repository maintainers, and those with the push access to the upstream repository, to commit to your forked branch.
- Choose at least one
area/{capability}
label from the available list and add it to your PR to categorize changes you made. Labels are required to include your PR in theCHANGELOG.md
file and classify it accordingly.
- After you create a PR, relevant CI tests need to complete successfully.
- If you are a Kyma organization member, all related CI tests run automatically after you create a PR. If a test fails, check the reason by clicking the Details button next to the given job on your PR. Make the required changes and the tests rerun. If you want to run a specific test, add the
/test {test-name}
or/retest {test-name}
comment to your PR. To rerun all failed tests, add the/retest
comment. - If you are an external contributor, contact the repository maintainers specified in the
CODEOWNERS
file to review your PR and add the/test all
comment to your PR to trigger all tests. A Kyma organization member needs to rerun the tests manually each time you commit new changes to the PR.
- Wait for the Kyma maintainers to review and approve your PR. The maintainers can approve it, request enhancements to your change, or reject it.
NOTE: The reviewer must check if all related CI tests have completed successfully before approving the PR.
- When the maintainers approve your change, merge the PR. If you are an external contributor, contact the repository maintainers specified in the
CODEOWNERS
file to merge the PR for you.
If you find a bug to report or you want to propose a new feature, go to the GitHub issue tracker of a given repository and create an issue. If you are not certain which repository your bug or feature relates to, raise it on the kyma
repository.
NOTE: The repository maintainers handle only well-documented, valid issues that have not been reported yet. Before you create one, check if there are no duplicates. Provide all details and include examples. When you report a bug, list the exact steps necessary to reproduce it.
See the issues-workflow document for details on issues triage and processing workflow.
Every maintainer reviews each contribution according to the rules listed in this document.
Although it is the responsibility of the owner of the PR to ensure that the maintainers review and approve the PR, maintainers need to coordinate the overall number of unreviewed and unapproved PRs in their queue, and, if required, take appropriate measures to handle them effectively.
To learn more about maintainers' responsibilities and rules for appointing new maintainers, and removing the existing ones, refer to the governance.md document.
To identify the owners of particular parts of your repository, see the CODEOWNERS
file in the root directory.