fbpx

Guide to Raising Pull Requests on GitHub

OMOTOLA SHOGUNLE

ARTICLE SUMMARY

In this 2nd guide from Omotola’s How to Get Good at Git & GitHub - she shares her insights into how to raise a pull request on GitHub.

SKIP THIS PART IF YOU HAVE BEEN FOLLOWING THE SERIES

If you are just joining us for this Git and GitHub Series, welcome! This is a miniseries on how to handle most of Git’s tasks, especially in a collaborative setting. To get the most of this, create a bookmark folder called Git Series and save this post to it for reference.

You're invited! Join SheCanCode's Women in Tech Community

Find a supportive network, opportunities, jobs & much more, so you can excel in your tech career.

Let’s Begin

Before I jump into the question of “How to raise a Pull Request?”, I have to discuss why it’s important and where it fits into the grand scheme of things.

Where does raising a PR fit in?

We use Git to manage source control. However, Git is just a tool and the way we use the tool to manage our code is critical. One prominent Git feature we use is branches. In a typical project, we have:

Master/Main Branch — Where we host the most stable version of code, which is also production ready.

Development Branch — Usually created from the main branch, and serves as a branch for merging other custom branches like features/fixes/releases branch. This is the branch where developers mainly collaborate on the integrity of the code written before they can merge it into the main branch

This is where raising PRs to a branch comes into play. Imagine a scenario where you create a feature branch off the development branch, and after you complete your changes, the next step is to merge it back into the development branch. To do this, raise a Pull Request to the development branch as the target. Your changes will now be open to other developers to review your code and either approve it or request changes.

So essentially, a PR (Pull Request) is a development process that provides an interactive way of reviewing and discussing code you are requesting to be merged into another branch.

To improve the quality of code 

  • It simplifies receiving feedback on your code from the reviewer
  • It’s open and collaborative and can serve as documentation.

Great; now that we have concluded on these two points, let’s move on to another subject!

1. Prerequisite; What needs to happen before a Pull Request? 

  • First – on your local computer, in the feature/fix/release branch, add and commit all the changes you would like to push to your remote branch. 
  • Then run git push -u origin feature/BLO-990, if it’s the first time you are pushing to the branch you created locally. Or run git push, if the branch already exists remotely.
  • This is the output you might see on your screen. Click on the first link.

pull request on Github

Note: The PR target branch requires being different to your branch for it to work. Here, we have feature/BLO-990 → development branch.

2. The Pull Request Process 

When you click on the link, it shows you a page where you will need to do a couple of tasks before clicking the CREATE PULL REQUEST button. 

This is what it looks like now: 

pull request on Github

Change base branch

When you raise a PR by default, it goes against the main/master branch, but depending on the branching model used in your workplace, you might want to first merge your changes to the develop/development branch.

pull request on Github

pull request on Github

Write a descriptive subject and body for your PR 

By default, the subject will use your last commit message. In the body, here is a chance to give a descriptive summary of your changes. You can also add screenshots, videos, links, and steps for manual testing etc. It’s a good rule of thumb to give as much detail as possible.

pull request on Github

Click on the Create Pull Request button 

If the checks ran successfully and there are no merge conflicts, there should be an attractive MERGE PULL REQUEST button shown. Don’t do it! This is where you invite other developers to review your code, so they can approve it. This needs to happen before you can merge it.

pull request on Github

Assign Yourself, Tag Reviewers and Optional Labelling

On the right-hand side of your PR you should see a column with the titles Assignees, Reviewers, and Labels. Assign yourself the PR, and then tag another developer to review the PR under Reviewers, and optionally you can add/create a label like pending review or requires review or help wanted.

pull request on Github

The Review Process begins

The reviewer normally gets a notification in their inbox to review your PR. To add feedback or modifications, the reviewer comments near the line of code. As the developer, they expect you to reply to the comments or resolve the issue by making the changes requested and pushing again. Normally, a circle icon appears close to the reviewer’s name to notify them you have made recent changes that need another review. You should click on the icon when you are ready for another review.

This process continues until you resolve all discussions.

Merge changes to the Selected Branch

Once a developer approves your changes, you can click on the green, shiny button that says MERGE PULL REQUEST. Then click on CONFIRM MERGE, and this appears. You can decide to discard the branch or keep it. I vote to discard it, to keep things tidy.

pull request on Github

BONUS

How to change the BASE Branch of an Existing PR

To do this, follow these steps:

Under your repository name, click Pull requests.

pull request on Github

In the “Pull Requests” list, click the pull request you’d like to modify.

Next to the pull request’s title, click Edit.

pull request on Github

In the base drop down menu, change it to the branch you would like to compare changes to

Github code screen

Click Change Base

pull request on Github

I enjoyed writing this post because it was very practical! I hope you enjoyed reading it too? In the next post, I will be writing about How to Resolve a Merge Conflict.

Remember, you can always message/tag me on Instagram @mycodinghabits if you found this helpful, or email me mycodinghabits@gmail.com if you have questions.

A pull request (PR) is a way to propose changes to a repository on GitHub. It allows developers to suggest edits, additions, or fixes, which can then be reviewed, discussed, and merged into the main branch by the repository maintainers. Pull requests are essential for collaboration in open-source and team projects.

Here’s a simple guide to create a pull request in GitHub:

  1. Fork the repository you want to contribute to.
  2. Clone it to your local machine using git clone.
  3. Create a new branch using git checkout -b branch-name.
  4. Make your changes and commit them with git commit.
  5. Push the branch to your fork with git push origin branch-name.
  6. Go to the original repository on GitHub, and click New Pull Request.
  7. Compare changes, add a title, description, and submit!

A pull request gets its name because you’re asking the repository owner to pull your changes into their repository. This reflects the underlying Git operations, where the changes need to be “pulled” and merged by the maintainer.

To delete a pull request in GitHub:

  1. Navigate to the pull request page in the repository.
  2. If it hasn’t been merged yet, you’ll need to close it first by selecting the Close Pull Request button.
  3. Note that you cannot completely delete a pull request record; GitHub maintains it for transparency and collaboration history.

No, git clone and a pull request are not the same.

  • git clone: Creates a local copy of a repository on your computer.
  • Pull request: Suggests changes to an existing repository that can be reviewed and merged by the maintainer.

While both involve GitHub workflows, they serve completely different purposes.

To set up a Git repository and pull from GitHub:

  • Install Git on your machine and configure it with your credentials using:

git config –global user.name “Your Name”
git config –global user.email “your.email@example.com”

  • Clone a repository using:

git clone <repository-url>

  • Navigate to the directory and make changes.
  • Pull the latest changes from the main repository using:

git pull origin main

To pull a repository from GitHub to your local machine:

  1. Copy the repository’s URL from GitHub (using the green Code button).
  2. Open your terminal or command prompt.
  3. Run the following command:
    bash
    git clone <repository-url>
  4. This will download the entire repository to your machine, including all branches.

RELATED ARTICLES

Regression analysis is one of the most fundamental concepts in machine learning. This article briefly introduces linear and logistic regression and how to implement them...
This article provides practical strategies and insights to help you cope if you are suddenly laid off.
As a developer, there are several websites that you may find useful and interesting. Here are a few recommendations.
With over 700 programming languages in existence today, it can be a challenging task to know which programming language is right for your career. In...