+ - 0:00:00
Notes for current slide

Presenter notes contain extra information which might be useful if you intend to use these slides for teaching.

Press P again to switch presenter notes off

Press C to create a new window where the same presentation will be displayed. This window is linked to the main window. Changing slides on one will cause the slide to change on the other.

Useful when presenting.

Notes for next slide



Contributing with GitHub via command-line



last_modification Updated:   purlPURL: gxy.io/GTN:S00041

text-document Plain-text slides |

Tip: press P to view the presenter notes | arrow-keys Use arrow keys to move between slides
1 / 28

Presenter notes contain extra information which might be useful if you intend to use these slides for teaching.

Press P again to switch presenter notes off

Press C to create a new window where the same presentation will be displayed. This window is linked to the main window. Changing slides on one will cause the slide to change on the other.

Useful when presenting.

question Questions

  • How can I contribute to an open-source project with GitHub?

  • What is the GitHub flow?

2 / 28

objectives Objectives

  • Fork a repository on GitHub

  • Clone a remote repository locally

  • Create a branch

  • Commit changes

  • Push changes to a remote repository

  • Create a pull request

  • Update a pull request

3 / 28

Steps

  • Fork (copy) a GitHub repository in your GitHub space

  • Clone your GitHub repository on your system

  • Create a new branch (one branch = one new feature)

  • Make your changes on this branch

  • Push your branch on your GitHub repository

  • Merge your branch on the original GitHub repository

4 / 28

1. Fork a repository

5 / 28

Fork from a GitHub repository

Screenshot of github repository header with watch, star and fork buttons. The fork button highlighted

6 / 28

Welcome on your fork repository

Screenshot for a fork of the training material repository. It shows that it is username/training-material and it has been forked from the upstream.

7 / 28

Welcome on your fork repository

Cartoon of two github repositories, upstream and fork. Both have branches like main, feature1 and feature2.

8 / 28

2. Clone your GitHub repository

9 / 28

Get your GitHub URL

A subset of the github interface is shown with the green code button clicked. A popup is shown with options to clone from https or ssh, open in github desktop, or download a zip file.

10 / 28

Clone your GitHub repository

On your terminal:

  • clone your repository
$ git clone your_fork_github_url
  • go into your repository
$ cd training-material
11 / 28

Clone your GitHub repository

The cartoon from before with repositories upstream and fork are now shown to exist on github, and an arrow labelled clone is drawn to a local copy that exists locally.

12 / 28

3. Make your changes

13 / 28

Create your branch

List your branches

$ git branch
* main

a line with dots on it representing commits is labelled main has an arrow pointing to the end where there are no dots.

Create a new branch

$ git checkout -b my_new_branch
Switched to a new branch 'my_new_branch'
14 / 28

Make your changes

List your branches

$ git branch
main
* my_new_branch

The line with dots or commits is labelled main, now a different line comes out of the right most (i.e. latest) commit. this is labelled my new branch.

Make changes and commits

$ git add newfile1 newfile2 ...
$ git commit -m "my contribution"

The cartoon from above, however now there are commits shown on my new branch.

15 / 28

Make changes and commits

The cartoons of the three github repositories are back, upstream, fork, and local. Now local shows a new branch, my new branch.

16 / 28

Push your branch on your GitHub repository

$ git push origin my_new_branch

The same cartoon of the three repositories, an arrow labelled push is shown from the local copy to the fork, and now the my new branch is present in the fork, as well as locally like before.

17 / 28

4. The pull request

18 / 28

Can't push on the original GitHub repository

The same cartoon, but now two arrows are shown between the upstream and fork repositories on github. One arrow is labelled push and has an X over it, indicating a push cannot happen. However an arrow labelled pull request is shown in colour like it can happen.

19 / 28

Create your pull request

Screenshot of the github interface showing a yellow popup labelled "your recently pushed branches" with my new branch shown in the list. A green button reads compare and pull request.

20 / 28

Select the branches and write a description

The pull request form is shown titled "Open a Pull Request", the user is busy filling out the title of the pull request. A button at the bottom reads create pull request.

21 / 28

Automated tests can be executed

A screenshot of the training material on github, the pull request tab is highlighted. A number of pull requests appear below, some with green check marks, some with red crosses.

  • Green check mark = OK
  • Red cross = not OK
22 / 28

Your pull request is accepted (congrats)

  • Automated tests are ok

  • Authors have accepted your feature

  • Branches are merged

line with dots on it representing commits is shown, the line is labelled main as before, but now the commits from my new branch appear directly on the main branch.

23 / 28

Your feature is now in the original code

The same 3 repository cartoon as before, both the fork and local copy include my new branch, it looks like the author intended that upstream did too but it is missing from the graphic.

24 / 28

Your pull request need modifications (oops)

  • Automated tests are non ok

  • Authors have not accepted your feature

You have to make modifications on your branch and push it

25 / 28

Summary

A final version of the three repository graphic is shown, fork and upstream are on github, the local copy is local. There are several arrows: 1 fork, creating fork from upstream; 2 clone, creating local from fork; 3 push, pushing my new branch to fork; 4 pull request, starting the process of getting my new branch into upstream.

26 / 28

keypoints Key points

  • Work on your fork

  • 1 branch = 1 feature

  • 1 pull request = 1 branch

  • Be careful of the branch you're working on

  • Check the automated tests

27 / 28

Thank You!

This material is the result of a collaborative work. Thanks to the Galaxy Training Network and all the contributors!

Galaxy Training Network

Tutorial Content is licensed under Creative Commons Attribution 4.0 International License.

28 / 28

question Questions

  • How can I contribute to an open-source project with GitHub?

  • What is the GitHub flow?

2 / 28
Paused

Help

Keyboard shortcuts

, , Pg Up, k Go to previous slide
, , Pg Dn, Space, j Go to next slide
Home Go to first slide
End Go to last slide
Number + Return Go to specific slide
b / m / f Toggle blackout / mirrored / fullscreen mode
c Clone slideshow
p Toggle presenter mode
t Restart the presentation timer
?, h Toggle this help
Esc Back to slideshow