Skip to content

Test repository to learn GIT basics (commit/pull/push/branch/merge)

License

Notifications You must be signed in to change notification settings

dankcushions/gittology

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

gittology

A test repository to learn GIT basics (commit/pull/push/branch/merge)

Why

Out of sheer necessity we needed a way to let other team members, like designers, a way to test basic GIT actions (committing and pushing files, pulling from a repository). As always practice makes perfect, so I decided to create a GitHub repository for testing purposes.

Structure

Ideally we have different meaningful branches that can be used to perform the basic GIT operations, plus it could be used to experience the most basic case of conflict, rebase and squashed merge.

Git cheat sheet

A very interesting cheat sheet is available at GitHub (git-cheat-sheet), it's a must read to have a better idea of what are the commands used in this short guide.

Git

Git is a DVCS aka Distribuited Version Control System

Distributed revision control takes a peer-to-peer approach to version control, as opposed to the client-server approach of centralized systems. Rather than a single, central repository on which clients synchronize, each peer's working copy of the codebase is a complete repository. WikiPedia

How to use it

Fork this repository on GitHub top right Fork button.

$ git clone https://github.com/myGitHubUsername/gittology.git

Repository structure

The repository consists of 4 branches:

  • master
  • merge-conflict
  • merge-master
  • merge-standard

Any of them cover the most basic set of standard operations, starting from a simple merge to the most complex case of a conflict while merging.

Preparation

Fire up your terminal and $ cd in your repository folder, let's suppose that you've cloned it on your home directory:

$ cd ~/gittology

Standard operations

CHECKING BRANCHES

You are now on the master branch, which is the name of the default branch created by Git, as per convention is the main branch.

$ git branch -a show branches { local and remote }

Should return something like that

* master
  remotes/origin/HEAD -> origin/master
  remotes/origin/master
  remotes/origin/merge-conflict
  remotes/origin/merge-master
  remotes/origin/merge-standard

COMMIT

A brief check of the files contained in the repository, you should see a list of files like this one:

$ ls -l

-rw-------  1 jenoma  staff  1077 Jul 28 15:48 LICENSE
-rw-r--r--  1 jenoma  staff   678 Jul 28 15:49 README.md
-rw-r--r--  1 jenoma  staff   493 Jul 28 15:48 file_1.md
-rw-r--r--  1 jenoma  staff   493 Jul 28 15:48 file_2.md
-rw-r--r--  1 jenoma  staff   345 Jul 28 15:49 file_3.md

Open file_1.md* with your editor of choice and start adding a couple of random lines of written text.

* .md is a markdown file, you can open it with a markdown capable editor or as a plain text file

Now you should check the status of the repository with:

$ git status

[genoma:~/gittology-test]$ git status                                                                                                                                                                                                                                                                              (master✱)
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

	modified:   file_1.md

no changes added to commit (use "git add" and/or "git commit -a")
[genoma:~/gittology-test]$                                                                                                                                                                                                                                                                                         (master✱)

The changes, as your terminal is clearly telling you, are not staged for commit: this means that you have to add files into the stage area to commit them.

And that brings us to the next step:

$ git add -A add file/s to the stage area { add all files }

Than you should do the actual commit:

$ git commit -m 'added file' commit the staged file/s { with the commit message 'added files' }

IMPORTANT: the commit message is mandatory, if you don't provide the -m option it will be used Vi as the default editor to provide it.

PUSH and PULL

As you should know, your commits are local until they are pushed to the remote repository:

$ git push origin master push to the remote origin, branch master

Usually before pushing, if you are working in a team and on the same repo/branch you should do a pull before a push, because if something has changed on the remote repository while you were working Git will politely throws you an error asking to pull before push.

$ git pull origin master pull from the remote origin, branch master

$ git push origin master push to the remote origin, branch master

CAVEAT

git branch --set-upstream origin master allows to track the branch in which you are with the specified remote/branch: permits to omit the remote/branch declaration when pushing/pulling: $ git pull and $ git push

SIMPLE MERGE

This repository has been developed with some basic merge cases between branches:

  • merge-conflict
  • merge-master
  • merge-standard

Those three are the branches that we will use to test some merge testing.

Incorporates changes from the named commits (since the time their histories diverged from the current branch) into the current branch. (git-scm)

In few words it git-merge merges the changes from a branch to another.

While on master branch:

$ git fetch origin merge-standard:merge-standard get the remote branch merge-standard and put it as a local branch with the same name.

$ git merge merge-standard merge merge-standard into the branch i'm on right now

Merge standard is a simple merge without any sort of conflict, basically it should be painless and a straight forward process.

CONFLICT MERGE

Most difficult case, quite often present while working in a large team on complex projects.

While on master branch:

$ git fetch origin merge-conflict:merge-conflict get the remote branch merge-conflict and put it as a local branch with the same name.

$ git merge merge-conflict merge merge-conflict into the branch i'm on right now

$ git merge merge-conflict                                                                                (master)
Auto-merging file_3.md
CONFLICT (content): Merge conflict in file_3.md
Automatic merge failed; fix conflicts and then commit the result.

This is the actual conflict arising, now the problem is how to solve it.

Generally speaking you should use a program like (kdiff3)[http://kdiff3.sourceforge.net/] or similar, but you should able to solve it using your editor:

<<<<<<< HEAD
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, __This file will generate the conflict when merged with the `merge-conflict` branch__, sunt in culpa qui officia deserunt mollit anim id est laborum.
=======
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, __this is the conflict preparation__, sunt in culpa qui officia deserunt mollit anim id est laborum.
>>>>>>> merge-conflict

What you see is the file file_3.md that needs to have its conflict resolved:

- <<<<<<< HEAD _is the portion of the file in conflict before the merge_
- ======= _it's the delimiter between the two file versions_
- >>>>>>> merge-conflict _is the portion of the file in conflict present in the branch you're merging with (merge-conflict)_

Let's assume we'd like to have the conflict resolved with the version of the branch merge-conflict, what we have to do is delete the portion of the file content between the <<<<<<< HEAD and the delimiter =======

The result will be:

# This is the third file in your repository

Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, __this is the conflict preparation__, sunt in culpa qui officia deserunt mollit anim id est laborum.

MASTER MERGE

This a classic case: when developing on a feature/whatever branch for a long time you want to bring it in sync with the master branch that has changed.

$ git checkout merge-standard switch to the merge-standard branch

$ git merge master merge the master into your current branch

That's it, you have now incorporated the changes into your branch from the master one.

About

Test repository to learn GIT basics (commit/pull/push/branch/merge)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published