Introduction to Git

This course will be an introduction to version control, with a strong focus on Git.

Instructors:

  • Pedro Ojeda-May (HPC2N)
  • Birgitte Brydsö (HPC2N)
  • Diana Iusan (UPPMAX)

The course will have a mixture of lectures and hands-ons, and will be split into modules. It will consist of five half-days.


  • The lectures will be done in the main Zoom room.
  • Most modules will have hands-ons. These are done in the main Zoom room, but with the possibility to go to break-out rooms for help. There will also be a silent room for those who prefer to work undisturbed.
  • Some hands-ons will be done locally on your own computer and some will be done using GitHub.
  • If there is a problem using your own computer, the backup solution is logging in to Tetralith and using that (if you have an account).
  • The hands-ons for the module named “Teamwork” will be done in small groups, using GitHub.

  • During the hands-ons you can just ask the instructors if there is anything you need help with.
  • You can ask in the chat, but the recommended option is using the Questions and Answers page (Q&A page). The link can be found on the “Important information” page.
  • Please write any questions you have during the lectures etc. to the Q&A page. The instructors will try to answer as quickly as possible.
  • Scroll down on a slide page to get to access the slides in a text form (small pen icon)

Overview

1. day

  • Optional installation help (Git)
  • Course info
    1. Introduction and setup
    1. Motivation - Why use version management?
    1. Basics commands, part 1
    2. Creating & cloning repositories, Adding files, Committing, etc.
    3. Hands-on
    1. Basics commands, part 2
    2. Creating & cloning repositories, Adding files, Committing, etc.
    3. Hands-on

2. day

    1. Basic concepts, part 1
    2. Blobs, Trees, Commits, References, etc.
    1. Basic concepts, part 2
    2. Blobs, Trees, Commits, References, etc.
    1. Traversing the commit tree, part 1
    2. History, Tags, HEAD, Diffs, etc.
    3. Hands-on

3. day

    1. Traversing the commit tree, part 2
    2. History, Tags, HEAD, Diffs, etc.
    3. Hands-on
    1. Traversing the commit tree, part 3
    2. History, Tags, HEAD, Diffs, etc.
    3. Hands-on
    1. Branches, merges, and conflicts, part 1
    2. Basics concepts, Creation, deletion, Conflicts, etc.
    3. Hands-on

4. day

    1. Branches, merges, and conflicts, part 2
    2. Basics concepts, Creation, deletion, Conflicts, etc.
    3. Hands-on
  • C. Brief intro to SSH-keys and using GitHub
    1. Working with remotes, part 1
    2. Basics concepts, Pull, push, fetch, GitHub, etc.
    3. Hands-on
    1. Working with remotes, part 2
    2. Basics concepts, Pull, push, fetch, GitHub, etc.
    3. Hands-on

5. day

    1. Teamwork, part 1
    2. Hands-on
    1. Teamwork, part 2
    2. Hands-on
    1. Teamwork, part 3
    2. Hands-on
  • Catch-up from previous days