DEV Community

Cover image for The Practical Guide to Contributing to Open Source Projects
Vishwas Tyagi
Vishwas Tyagi

Posted on • Edited on • Originally published at vishwastyagi.hashnode.dev

The Practical Guide to Contributing to Open Source Projects

Table Of Contents

Introduction

Mike: Hey VT, you taught me about git over here. Since then, I am having a good time working with git.

I recently heard about the terms GitHub and Open Source Software. I am curious to know about them. Can you tell me something about them?

VT: Yeah, sure.

๐Ÿ’ก GitHub is basically a cloud-based website where you can host git repositories and collaborate with other people.

๐Ÿ’ก Open Source Software is a type of software that has freely accessible source code and is distributed under a license that allows you to examine, modify, and use the code without restriction.

Mike: Could you please explain how I can use GitHub?

VT: Ok, let's get into it.

Using GitHub

VT: Let's create a git repository and push it onto GitHub.

Mike: Ok, I'm excited.

๐Ÿ“Œ Make sure you have git installed before moving forward.

Creating a local git repository

1. Initialize a new git repository

VT: First, we have to create a git repository on our computer.

Open a terminal (or command prompt) in an empty folder or a project folder and run the following command:

$ git init
Enter fullscreen mode Exit fullscreen mode

Output:
Oputput of command git init

2. Create a file

VT: We now have a git repository set up. Let's create a new file.

Create a new file (or modify an existing one) in the folder where we set up the git repository.

Screenshot of index.html file with git repository

Let's call our file index.html and add the following code to it:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>GitHub Guide</title>
  </head>
  <body>
    <h1>Hello GitHub!</h1>
  </body>
</html>
Enter fullscreen mode Exit fullscreen mode

Save the file.

VT: Now, we can run this command to see our changes tracked by git.

$ git status
Enter fullscreen mode Exit fullscreen mode

Output:
Output of the command git status

3. Commit changes

VT: Let's commit our change.

Run the following commands:

$ git add index.html
$ git commit -m "added index.html"
Enter fullscreen mode Exit fullscreen mode

Output:
Output of command git commit

Mike: Ok, I have successfully committed my changes. What's next?

VT: Next, the exciting part, we will create a repository on GitHub.

Creating a repository on GitHub

1. Log in to GitHub

VT: First step, log in to GitHub.

๐Ÿ“Œ If you are new to GitHub, create a new account on GitHub.

GitHub sign-in page

๐Ÿ“Œ For security purposes, GitHub provides a PAT (Personal Access Token) to use in place of a password while pushing code to GitHub. Please generate your PAT as soon as you log in to GitHub for the first time. You can generate your PAT by following this guide.

2. Create a repository on GitHub

VT: Click the + icon in the upper right corner of the GitHub homepage.

Plus icon on GitHub

Select New repository.

New repository button GitHub

A page will open to create a new repository.

Enter the name and description (optional) for the new repository.

New repository name and description input fields

Choose whether to make the repository Public or Private.

Repository options Public or Private

Click the Create repository button at the bottom of the page.

Create repository button

VT: We now have a GitHub repository set up. Let's see how we can push our code to the GitHub repository.

Pushing code to the GitHub repository

1. Add remote to the local git repository

Mike: What do you mean by adding remote?

VT: Connecting our local git repository to a remote (online) repository, such as a GitHub repository, is what adding remote means.

It enables us to pull updates and push our changes to the remote repository.

We can add remote to our local git repository by running the following command:

$ git remote add origin URL_OF_GITHUB_REPOSITORY
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace URL_OF_GITHUB_REPOSITORY with the URL of your own GitHub repository with .git added at the end.

Output of git remote command

2. Rename the branch from master to main

VT: Before we can push our git repository to GitHub, we must rename the branch master to main.

Mike: Why do we have to rename the git branch?

VT: It's because GitHub uses main as its default branch, whereas git uses master.

Run the following command to rename the current branch to main:

$ git branch -M main
Enter fullscreen mode Exit fullscreen mode

3. Push code to GitHub

VT: Now, it's time to push our code to GitHub.

Run the following command:

$ git push -u origin main
Enter fullscreen mode Exit fullscreen mode

When prompted, enter your GitHub username and password.

๐Ÿ“Œ Use your PAT (Personal Access Token) in place of the password.

Output of git push command

Congratulations! We now have a complete GitHub repository.๐ŸŽ‰๐ŸŽ‰


Contributing to Open Source Projects

Step 1: Finding the repository to contribute to

VT: To contribute to an open-source project, we must first navigate to the project's GitHub repository.

But, for practice, I've set up a GitHub repository called github-playground. You can find it here.

๐Ÿ“Œ I recommend that you follow this guide and contribute to the GitHub repository (github-playground).

VT: Go to https://github.com/vishwast03/github-playground

Step 2: Forking the repository

Mike: What do you mean by 'forking'?

VT: Here, 'forking' means copying the original repository to our own account.

To Fork the repository, click on the Fork button in the upper-right corner of the repository.

Fork button on GitHub

On next page, click Create fork button at the bottom.

Create fork button on GitHub

Step 3: Cloning the fork

VT: Now, we have to clone the forked repository to our local machine using git.

Cloning means copying a remote repository to our local machine. It is done to be able to work on the project.

To clone:

  • First click the Code button on the forked project on your GitHub.

Code button on GitHub

  • Copy the URL from the tab opened.

Repo URL tab on GitHub

  • Run the following command to clone the forked repository.
$ git clone URL_OF_FORK
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace URL_OF_FORK of with the URL you have copied in the previous step.

Output:
Output of git clone command

Step 4: Navigating to local repository

VT: Use the following command to navigate to the local repository:

$ cd NAME_OF_REPOSITORY
Enter fullscreen mode Exit fullscreen mode

Step 5: Checking the "origin" remote

VT: Now, we will check if our fork is added as remote origin or not.

Use the following command to list all the remotes:

$ git remote -v
Enter fullscreen mode Exit fullscreen mode

The output of above command should look like this:
output of git remote command

๐Ÿ“Œ If your fork was not added correctly as origin, you can use the following command to add it manually:

$ git remote add origin URL_OF_FORK
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace URL_OF_FORK with the URL of your fork on GitHub.

Step 6: Adding the "upstream" remote

VT: Before we start working on the project, we have to add the original project repository as remote upstream in our local repository.

It enables us to pull updates from the main project.

Use the following command to add remote upstream to our local repository:

$ git remote add upstream URL_OF_PROJECT
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace URL_OF_PROJECT with the URL of the original project (not fork).

You can check if the remote was added or not by running the following command:

$ git remote -v
Enter fullscreen mode Exit fullscreen mode

The output should look like this:
Output of git remote after adding upstream

Step 7: Pulling the latest changes

VT: It is the best practise to always download the most recent changes from upstream before beginning work on a project.

Run the following command to pull the latest changes from upstream into our local repository:

$ git pull upstream main
Enter fullscreen mode Exit fullscreen mode

Output:
Output of git pull command

Step 8: Creating a new branch

VT: Let's create a new branch to begin our work.

๐Ÿ’ก Always create a new branch before working on the project.

Run the following command:

$ git checkout -b BRANCH_NAME
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace BRANCH_NAME with the name you want to give to your branch (e.g. feature).

You can list all your branches by running the following command:

$ git branch
Enter fullscreen mode Exit fullscreen mode

Output:
Output of git branch command

Step 9: Making changes

VT: It's time to make some change to our project.

If you are working on github-playground project then, open Players.md file in your favourite text editor.

Add the following line to Players.md file:

- [YOUR_NAME](YOUR_PROFILE_URL)
Enter fullscreen mode Exit fullscreen mode

Name and profile added to Players.md

๐Ÿ“Œ Make sure to replace YOUR_NAME with your real name and YOUR_PROFILE_URL with your profile URL (you can share any profile that you want, e.g. GitHub, Twitter, dev.to, etc.).

๐Ÿ“Œ If you don't want to share your profile, write your name like this:

- YOUR_NAME
Enter fullscreen mode Exit fullscreen mode

Only name added to Players.md

Save the file.

Step 10: Committing changes

VT: Let's now make a commit to the repository.

Run the following command to add the change to staging area and make a commit to the repository:

$ git add .
$ git commit -m "DESCRIPTION_OF_CHANGES"
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace DESCRIPTION_OF_CHANGES with the actual description.

Output:
Output after running git commit command

Step 11: Pushing changes to fork

VT: We will now push our changes to our forked repository.

Mike: Why do we have to push the changes to the forked repository? Can't we just push to the original repository?

VT: We can't push the changes directly to the original repository. We don't have access to that repository.

We must first push the changes to the forked repository, then we will make a pull request from there.

Run the following command to push the changes to the forked repository:

$ git push origin BRANCH_NAME
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace BRANCH_NAME with the name of the branch you are working with.

When prompted, enter your GitHub username and password.

๐Ÿ“Œ Use your PAT (Personal Access Token) in place of the password.

Output:
Output of git push command

Step 12: Creating a pull request

VT: Now it's time to make a pull request.

Navigate to the forked repository on GitHub.

A prompt to make a pull requset must have appeared.

Click the button labelled Compare & pull request.

Compare & pull request button

On the next page, add the Title and Description to your pull request.

Pull request title and description input

Now, click Create pull request button at the bottom.

Create pull request button

We have successfully created a pull request. Cheers!

Pull requset created successfully

Mike: Oh! Great! What do we have to do next?

VT: Now we must discuss the pull request with the maintainer of the repository and, if necessary, make additional changes.

Step 13: Discussing the pull request

VT: Now that we've made a pull request, the repository's owner/maintainer will be notified about it.

The maintainers may initiate a discussion about the pull request and, if necessary, suggest changes.

If they are satisfied with the changes we have made, they will either merge the changes back into the original repository or suggest some changes.

If they have suggested any changes, we must implement them and make another commit to the existing pull request.

Step 14: Adding more commits to the existing pull request

VT: If we need to make changes after submitting a pull request, we must go to our local git repository and make the changes there.

To do so, we must switch to the branch on which we were previously working.

Run the following commands to check and switch the branch:

$ git branch
$ git checkout BRANCH_NAME
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace BRANCH_NAME with the name of the branch you were working with.

Output:
Output while switching branch

Now that we've switched to the branch with which we'll be working, we simply need to repeat steps 9 through step 11.

Step 15: Discussing the pull request again

VT: We must now re-discuss the pull request with the repository's maintainers.

If the maintainers approve and merge your changes, you will have made your first contribution to open source. It's time to celebrate.๐ŸŽ‰๐ŸŽ‰

Mike: Yay!!

Step 16: Deleting branch from the fork

VT: We now need to do some cleanup.

We have to delete the branch from our fork on GitHub.

To do so, we must first navigate to our forked repository page and open the dropdown labeled with the branch name main.

Branch dropdown menu

Click View all branches at the bottom of the dropdown menu.

View all branches link

Click the delete button corresponding to the branch with which we were working.

Delete branch button

Click Delete from the popup which will appear.

Step 17: Deleting branch from the local repository

VT: Now, we will delete the branch from our local repository.

First switch to the main branch by running the following command:

$ git checkout main
Enter fullscreen mode Exit fullscreen mode

Now, run the following command to delete the branch from local git repository:

$ git branch -D BRANCH_NAME
Enter fullscreen mode Exit fullscreen mode

๐Ÿ“Œ Make sure to replace BRANCH_NAME with the name of the branch you were working with.

Output:
Output of delete branch command

Step 18: Synchronizing the fork with the project repository

VT: Finally, if we intend to contribute to this project in the future, we must synchronise our fork with the project repository.

Just run the following command to do so:

$ git pull upstream main
$ git push origin main
Enter fullscreen mode Exit fullscreen mode

Enter the username and password when prompted.

๐Ÿ“Œ Use your PAT (Personal Access Token) in place of the password.

These commands will pull the most recent changes from the project repository and push them to our fork.

Congratulations on your first contribution to open source!๐ŸŽ‰๐ŸŽ‰

I hope you found something helpful in this post. You can also follow me on LinkedIn and Twitter.

Cheers and see you in the next one! โœŒ๏ธ

Top comments (0)