Contributing to the CORTX project using Git is a four-step process as listed below.
Click to expand!
Before you contribute to the CORTX project, you'll have to Fork the CORTX repository to clone it into your private GitHub repository.
Click to expand
-
Navigate to the repository homepage on GitHub.
-
Click Fork
-
Run the following commands in Shell:
$ git clone --recursive https://github.com/Seagate/<repository>.git
-
You'll need to setup the upstream repository in the remote list. This is a one-time activity. Run the following command to view the configured remote repository for your fork.
$ git remote -v
Sample Output:
origin [email protected]:<gitgub-id>/cortx-sspl.git (fetch) origin [email protected]:<github-id>/cortx-sspl.git (push)
-
Set up the upstream repository in the remote list using:
$ git remote add upstream https://github.com/Seagate/<repository>.git
$ git remote -v
Sample Output:
origin [email protected]:<gitgub-id>/cortx-sspl.git (fetch) origin [email protected]:<github-id>/cortx-sspl.git (push) upstream [email protected]:Seagate/cortx-sspl.git (fetch) upstream [email protected]:Seagate/cortx-sspl.git (push)
-
Check out to your branch using:
$ git checkout "branchname"
$ git checkout -b 'your-local-branch-name
📃 Note: By default, you'll need to contribute to the main branch.
Click to expand!
You can make changes to the code and save them in your files.
-
Use the command below to add files that need to be pushed to the git staging area:
$ git add foo/somefile.cc
-
To commit your code changes use:
$ git commit -s -m ‘comment’
- enter your GitHub Account ID and an appropriate Feature or Change description in comment. -
Check out your git log to view the details of your commit and verify the author name using:
$ git log
📃Note: If you need to change the author name for your commit, refer to the GitHub article on Changing author info.
-
To Push your changes to GitHub, use:
$ git push origin 'your-local-branch-name'
Sample Output
Enumerating objects: 4, done. Counting objects: 100% (4/4), done. Delta compression using up to 2 threads Compressing objects: 100% (2/2), done. Writing objects: 100% (3/3), 332 bytes | 332.00 KiB/s, done. Total 3 (delta 1), reused 0 (delta 0) remote: Resolving deltas: 100% (1/1), completed with 1 local object. remote: remote: Create a pull request for 'your-local-branch-name' on GitHub by visiting: remote: https://github.com/<your-GitHub-Id>/cortx-s3server/pull/new/<your-local-branch-name> remote: To github.com:<your-GitHub-Id>/reponame.git * [new branch] <your-local-branch-name> -> <your-local-branch-name>
📃Note: At any point in time to rebase your local branch to the latest main branch, follow these steps:
$ git pull origin main
$ git submodule update --init --recursive
$ git checkout 'your-local-branch'
$ git pull origin 'your-remote-branch-name'
$ git submodule update --init --recursive
$ git rebase origin/main
Click to expand!
-
Once you Push changes to GitHub, the output will display a URL for creating a Pull Request, as shown in the sample code above.
📃Note: To resolve conflicts, follow the troubleshooting steps mentioned in git error messages.
-
You'll be redirected to GitHib remote.
-
Select the relevant repository branch from the Branches/Tags drop-down list.
-
Click Create pull request to create the pull request.
-
Add reviewers to your pull request to review and provide feedback on your changes.
Perform the below mentioned procedure to create an issue in GitHub:
- Login to GitHub with your credentials.
- Navigate to the CORTX repository or relevant submodule. Then, click Issues. List of issues are displayed.
- If there are multiple issue types, click Get started next to the type of issue you'd like to open.
- Click New Issue. A page requesting the Title and Description is displayed.
- Enter a title and description for your issue, and click Submit new issue.
📃 Note: Click Open a blank issue if the type of issue you want to open, is not included in the available different types of issues.