Workshop on the basics of git Will be hold on 29th of January in 5416.0057 from 13:00 to 17:00 https://myuniversity.rug.nl/infonet/medewerkers/intracom/calendar/workshop-introduction-git
Go to file
2020-01-15 16:00:13 +01:00
.gitignore add gitignore 2020-01-14 16:41:17 +01:00
icecream.py Add icecream python snippet 2020-01-09 15:30:16 +01:00
README.md Add break 2020-01-15 15:39:47 +01:00
visualize-git.md Add line breaks 2020-01-15 16:00:13 +01:00

How to Git started

This is the information provided for the git workshop held at the CIT on the 29th of January 2020.

Table of Contents

Install Git

Download git for your operating system at: git-scm.com/downloads

Using a GUI

You can use any GUI for git, the one we will be using for this workshop is Sourcetree
Another recommended GUI to use it Fork.
You can download these at https://www.sourcetreeapp.com/ and https://git-fork.com/

For other GUIs check out https://git-scm.com/downloads/guis/

Our remote git server is located at https://git.web.rug.nl/
You can log in with your usual p-number and password.

This README has been written in markdown.
To get started see the following cheat sheet:

Cheatsheets:
Markdown

Learning objectives

  • Introduction to VCS
  • Create new repository
  • README.md
  • Git ignore file
  • Stage
  • Commit
  • Push / pull
  • Fork
  • Pull request
  • Branche
  • Merge / Rebase
  • Undoing Things
    • Amend commits
    • Unstaging
    • Unmodifying a modified file
    • Revert and reset
  • Tag
  • Log

Assignments

Assignment 1: Create a repository

  1. Create your own new repository
  2. Add a .gitignore file
  3. Why you would like a gitignore file
    • Not pushing sensitive files
    • Not pushing environment files
  4. Add a README.md

Assignment 2: Your first commit

  1. Clone repository
  2. Edit README file
  3. Create a new file(s) and add information
  4. Stage README and your file(s)
  5. Commit README and your file(s)

Assignment 3: Merge conflicts

  1. Go to the How to Git started repository
  2. Add icecream.py to your repository
  3. Choose a partner
  4. Add him/her as a collaborator
  5. Make the partner clone your repository
  6. Let both of you edit the same line in the code file
  7. Let one of you stage and push the changes
  8. Solve the merge conflict

Assignment 5: Branching

  1. Go to the How to Git started repository
  2. Add index.html to your shared repository.
  3. Let person A create a new branch called header
  4. Let person B create a new branch called footer
  5. Let person A edit the header of index.html
  6. Let person B edit the footer of index.html
  7. Stage and push the changes
  8. Pull the latest changes
  9. Track the branch of your partner

Assignment 6: Merge branches (Or Rebase)

  1. Go to your master branch
  2. Merge it with the header branch
  3. Commit the merge
  4. Merge it with the footer branch
  5. Commit the merge
  6. Push the changes
  7. Delete your old branches

Assignment 7: Pull requests

  1. Let one of you create a new repository (do not add collaborators)
  2. Stage and commit a file
  3. Let the other person fork the repository and clone it
  4. Let him/her change the file and push it
  5. Let him/her create a new pull request via the GUI
  6. Let the other approve and merge the request
  7. Let the other pull the latest changes

Assignment 8: Undo / Revert commit

Assignment 9:

Check the logs

Using the terminal

Configure tooling

Configure user information for all local repositories

$ git config --global user.name "[name]"
# Sets the name you want attached to your commit transactions
$ git config --global user.email "[email address]"
# Sets the email you want attached to your commit transactions
$ git config --global color.ui auto
# Enables helpful colorization of command line output
$ git config --global core.editor "nano" 
# Sets the default editor to nano

If you want to save your https credentials run

git config --global credential.helper store
Omit --global to set the identity only in this repository.

Or you can add an SSH key

Check your config using

$ git config --list

Terminal commands

See changes that have been made

git diff

Adding files to commit

git add file1 file2
git add *

Committing files with commit message, this will stage your changes

git commit -m "your commit message"

unstage by using

use "git reset HEAD <file>..." to unstage

Branches

Branches are an important part of working with Git. Any commits you make will be made on the branch youre currently “checked out” to. Use git status to see which branch that is.

Creates a new branch

$ git branch [branch-name]
$ git checkout -b [branch-name]

Switches to the specified branch and updates the working directory

$ git checkout [branch-name]

Combines the specified branchs history into the current branch. This is usually done in pull requests, but is an important Git operation.

$ git merge [branch]

Deletes the specified branch

$ git branch -d [branch-name]

Show all available branches

git branch -a

Track remote branch

git checkout --track origin/<branch>

Delete remote branch

git push <remote_name> --delete <branch_name>
git remote prune <remote_name>

Check the log in graph form

git log --graph --oneline

Glossary

  • git: an open source, distributed version-control system
  • GitHub: a platform for hosting and collaborating on Git repositories
  • commit: a Git object, a snapshot of your entire repository compressed into a SHA
  • branch: a lightweight movable pointer to a commit
  • clone: a local version of a repository, including all commits and branches
  • remote: a common repository on GitHub that all team members use to exchange their changes
  • fork: a copy of a repository on GitHub owned by a different user
  • pull request: a place to compare and discuss the differences introduced on a branch with reviews, comments, integrated tests, and more
  • HEAD: representing your current working directory, the HEAD pointer can be moved to different branches, tags, or commits when using git checkout

Resources

https://gitexplorer.com/
https://git-school.github.io/visualizing-git/
https://education.github.com/git-cheat-sheet-education.pdf
https://gitsheet.wtf/
https://www.keycdn.com/blog/git-cheat-sheet