mirror of https://github.com/grpc/grpc.git
The C based gRPC (C++, Python, Ruby, Objective-C, PHP, C#)
https://grpc.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
137 lines
5.2 KiB
137 lines
5.2 KiB
# Contributing to gRPC: A Step-By-Step Guide |
|
|
|
Note: This document is not meant for Google employees. |
|
|
|
## Prerequisites |
|
|
|
To contribute to the gRPC codebase, you need the following: |
|
|
|
1. An |
|
[active GitHub account](https://docs.github.com/en/get-started/quickstart/creating-an-account-on-github) |
|
1. [An understanding of Git and GitHub](https://docs.github.com/en/get-started/using-git/about-git) |
|
1. [Knowledge of how to fork a repository, clone a repository, merge, rebase, |
|
resolve, push, pull, fetch |
|
etc.](https://docs.github.com/en/get-started/using-git/about-git) |
|
1. [git installed and working on your machine](https://github.com/git-guides/install-git) |
|
1. Knowledge of the language being used, which can be C++, Python, Ruby, |
|
Objective-C, PHP, or C#. |
|
|
|
## Steps to Contribute gRPC C++ Code |
|
|
|
The GitHub repository for the C-based gRPC (C++, Python, Ruby, Objective-C, PHP, C#) |
|
is at https://github.com/grpc/grpc. |
|
|
|
### Fork and Clone the Repository |
|
|
|
If you want to contribute to the gRPC code base, you need to make a fork of the |
|
repository. |
|
|
|
1. Create your |
|
[own fork](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/fork-a-repo) |
|
from https://github.com/grpc/grpc. |
|
|
|
data:image/s3,"s3://crabby-images/ca9b7/ca9b7e5dfa6d9452ff096b7660a55cd5b48645a8" alt="Screenshot of creating fork using a non-google account." |
|
|
|
1. [Clone your fork](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/fork-a-repo#cloning-your-forked-repository) |
|
on your local machine. |
|
|
|
### Prepare and Push Your Commit |
|
|
|
1. In your cloned repository, create a new branch from `master`. |
|
1. Then prepare a commit for the files that you want to contribute. |
|
1. Commit to this branch. |
|
1. Push the commit to your fork on GitHub. |
|
|
|
Take care that your commits are aligned with these |
|
[guidelines](https://github.com/grpc/grpc/blob/master/CONTRIBUTING.md#guidelines-for-pull-requests). |
|
|
|
### Prepare a Pull Request |
|
|
|
After pushing your commit, visit https://github.com/grpc/grpc . If the |
|
forking, branch creation, commit and push have been successful, you will see |
|
the following message: |
|
|
|
data:image/s3,"s3://crabby-images/50fc7/50fc7d6575315672d59f9ec464a4906e84b1ae61" alt="Screenshot of Github UI to help to create a pull request." |
|
|
|
Take care to allow edits by maintainers. If there is a specific issue |
|
with your pull request, the maintainer can help if needed. This access to help will reduce |
|
the turnaround time for your submission. |
|
|
|
data:image/s3,"s3://crabby-images/4d20f/4d20fbc3f89f01ed41e8939034c6a36f809577cc" alt="Screenshot of Github UI to help to create a Pull Request." |
|
|
|
Create a pull request. |
|
|
|
### Pull Request Status - Safe Review |
|
|
|
Once the pull request is ready, you must wait for a reviewer to be |
|
assigned to your pull request. |
|
|
|
If you see *Not Covered* in the EasyCLA screen, as shown in the following image, |
|
click on the mentioned link to start the authorization process. |
|
|
|
data:image/s3,"s3://crabby-images/9c814/9c814e5032ecfdaca5e7833c6db516c0d066ec94" alt="Screenshot of waiting for safe review" |
|
|
|
You will see a series of screens: |
|
|
|
1. Select *Authorize LF-Engineering: |
|
|
|
data:image/s3,"s3://crabby-images/88924/88924ef7391a0f58a0dba93cb56a2ab1f01be1ca" alt="Screenshot of EasyCLA Step 1" |
|
|
|
1. Select your contributor type: |
|
|
|
data:image/s3,"s3://crabby-images/e8fab/e8fabea148d07e1a379f32ba5ac14cb8743d8f3b" alt="Screenshot of EasyCLA Step 2" |
|
|
|
1. Select *SIGN CLA*: |
|
|
|
data:image/s3,"s3://crabby-images/80311/803114d838245f4e992e406986ad2fbc91f12e63" alt="Screenshot of EasyCLA Step 3" |
|
|
|
Some time after you've digitally signed the document, the EasyCLA will appear as |
|
*Covered*. |
|
|
|
data:image/s3,"s3://crabby-images/40b89/40b89f9f6d28eb0253f9d950d2793e596c1bbe66" alt="Screenshot of EasyCLA Step 5" |
|
|
|
After a few hours, you will notice a new "assignee" assigned to the pull request. |
|
|
|
data:image/s3,"s3://crabby-images/761c1/761c1bbffc26a0669e47bfa27f1342dda68fa6cf" alt="Screenshot after an assignee is added" |
|
|
|
After a reviewer is assigned to you, they will help with the next |
|
steps, which are as follows: |
|
|
|
1. You complete the code review and address the comments. |
|
1. Your reviewer may add a few labels as needed. |
|
|
|
### Pull Request Status - Green |
|
|
|
Once you have approval from the reviewer, check if the tests are running. After |
|
the tests are complete, look at the status of all the tests. If |
|
everything is green, everything is good. But usually some failures exist. If |
|
there are failures, select each failure. The selection will take you to a page |
|
that has error details. Try to fix the issue. |
|
|
|
### Pull Request Approval |
|
|
|
For pull requests that are non-trivial, there is a thorough code review process. |
|
You can read more about the process and requirements |
|
[here](https://github.com/grpc/grpc/blob/master/CONTRIBUTING.md#guidelines-for-pull-requests). |
|
|
|
After you fix the code review, you will finally get an approval. After getting |
|
approval, you can submit the pull request. |
|
|
|
data:image/s3,"s3://crabby-images/eea1a/eea1a8f9378d0def062517e6e0fc424baff089fd" alt="Pull request approved and labelled" |
|
|
|
### Submission |
|
|
|
You **cannot** do submission or merge of a pull request through Github. |
|
|
|
data:image/s3,"s3://crabby-images/56043/5604315b42dc85e0dae461a2e61e33ec1e17e2d6" alt="Pull request approved and labelled" |
|
|
|
After you have approval from a reviewer, a Google employee will trigger |
|
the submission process. When the submission happens: |
|
|
|
1. A commit with your changes, along with a few additional formatting changes, will |
|
be committed to the `grpc/master` branch. |
|
data:image/s3,"s3://crabby-images/a17fa/a17fa3ae1a8efb4be5db773bd589ced60fa29fd5" alt="Copybara commit" |
|
|
|
1. The pull request you originally created will be closed. |
|
data:image/s3,"s3://crabby-images/d6702/d670224010d2145f616fdec8933b3a7bdbf1abe7" alt="Pull request closed by copybara" |
|
|
|
|