data:image/s3,"s3://crabby-images/b45a4/b45a4e8b5bc4d10afeb908f2d66d3baad7712d32" alt=""
Source Code Management
Ashish Pandey
@ashishapy
blog.ashishapy.com
data:image/s3,"s3://crabby-images/8dfd4/8dfd425a8a9bb7a09defb0ef2081cfa09c025bc0" alt=""
Meet-up on 17th July 2016
@ Thoughtworks Pune
Agenda
data:image/s3,"s3://crabby-images/22d4c/22d4c6d7dd001532851fcb9de5de96362282db99" alt=""
-
Git Introduction & Basics
-
Remote Repository (Cloud & Self) Hosting
-
Workflows
-
Branching
-
Git for DevOps
-
Github Features
data:image/s3,"s3://crabby-images/ee866/ee866ddb644d363d9e6c3a5e0171270fe4482f2e" alt=""
Distributed Version Control System (DVCS)
Command Line Interface (CLI)
Official Git site is https://git-scm.com
Good place to learn
Learn git in 15 mins https://try.github.io/
Project based learning https://learn.wheelhouse.io/
Learn from Github expert https://services.github.com/
Git tutorial https://www.atlassian.com/git/
data:image/s3,"s3://crabby-images/e1c92/e1c928a9354ae82f9a5115eb2f521ce834fb387b" alt=""
data:image/s3,"s3://crabby-images/51af8/51af87187ac980a64c5ea2caad5adb21c72f4c4e" alt=""
Origin
- Git development began in April 2005, after many developers of the Linux kernel gave up access to BitKeeper
- Started as Linux Kernel project
- Torvalds started the project when none of the available free systems met his needs
- Install git from https://git-scm.com/
-
$ git help
-
$ git config --global user.name "Ashish Pandey"
-
$ git config --global user.email ashishapy@gmail.com
-
$ git config --global color.ui true
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
$ git config --global alias.<alias-name> <git-command>
data:image/s3,"s3://crabby-images/e8d85/e8d85d928a44c7272a4d2004e5f0cca3da29114e" alt=""
Starting a remote repo
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
data:image/s3,"s3://crabby-images/29be7/29be7bdb2e7373ed3e1149c9242b873e7d3924e1" alt=""
Starting a local repo
$ git init
$ git remote add origin https://github.com/ashishapy/git-scm-demo.git
$ git clone https://github.com/ashishapy/git-scm-demo.git
OR
$ git status
$ git remote -v
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
~/.gitconfig
./.git/
data:image/s3,"s3://crabby-images/f15fd/f15fd5e20365d68d59a18683f1529753df05a708" alt=""
data:image/s3,"s3://crabby-images/42ec6/42ec6c5c9a4a66bd6b2d96d6aaa9f733e9c8f3f9" alt=""
Git Flow
data:image/s3,"s3://crabby-images/eee91/eee91ea47a69e2d3e0a427f893d9c856282da430" alt=""
$ git add -A
$ git commit -m "commit message"
$ git push
$ git pull
$ git checkout
$ git status
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
Different ways to add
$ git add <list of files>
$ git add --all / git add -A
$ git add *.txt
$ git add docs/*.txt
$ git add docs/
$ git add "*.txt"
Add all .txt files in the whole directory
git reset HEAD <file>
Add list of files
Add all files
Add .txt of files from current directory
Add .txt of files from docs directory
Add all files from docs directory
Unstage file changes
data:image/s3,"s3://crabby-images/eee91/eee91ea47a69e2d3e0a427f893d9c856282da430" alt=""
Make a good commit
Atomic
Consistent
Incremental
Documented
Semantically related changes should not be split across commits
Changes in a commit should be semantically related
A commit should not introduce compilation errors
A commit should not break existing tests nor add a failing one
Commit should be ordered deliberately
Commits should show programmers's thought process
A commit message should include a short summary
A commit description can have longer description
Changes after commit
$ git reset --soft HEAD^
$ git commit --amend -m "new commit message"
$ git reset --hard HEAD^
$ git reset --hard HEAD^^
Undo last commit, put changes into staging
Change the last commit
Undo last commit and all changes
Undo last 2 commits and all changes
data:image/s3,"s3://crabby-images/835ea/835ea00a99dcc8fdd843f6ef36cb916855a4e858" alt=""
After you Push
$ git rebase <base>
Move a branch to a new base commit
data:image/s3,"s3://crabby-images/eee91/eee91ea47a69e2d3e0a427f893d9c856282da430" alt=""
data:image/s3,"s3://crabby-images/12b5c/12b5c159ab0bee41d239264d61585480717d0f01" alt=""
Looking at History
data:image/s3,"s3://crabby-images/29fbd/29fbd9686f9b6ba9b51438188106a80c05a06ff1" alt=""
SHA hash
commit message
$ git log --oneline [-p] [--stat] [--graph]
$ git log --pretty="%h %ad- %s [%an]"
Run "git help log" for more options
$ git log --since=1.month.ago --until=2.weeks.ago
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
$ git log file
diffs
$ git diff
$ git diff --staged
$ git diff HEAD
$ git diff 4fb063d..56ght76
$ git diff master new_feature
$ git diff --since=1.month.ago --until=2.weeks.ago
$ git blame index.html --date short
diff between range of SHA
diff between last commit & current state
diff between two branches
time based diff
diff between last commit & staged changes
diff between staged changes & working copy
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
Undoing Changes
$ git checkout <commit> <file>
$ git checkout <commit>
$ git revert <commit>
$ git reset <file>
$ git reset
$ git reset --hard
$ git clean -n
$ git clean -f
$ git clean -df
$ git clean -xf
The git revert command undoes a committed snapshot.
Permanent undo
removes untracked files from your working directory
data:image/s3,"s3://crabby-images/c5a0a/c5a0ab38317e3f44b0a6fad3b9df4a3d5070ca92" alt=""
data:image/s3,"s3://crabby-images/0d697/0d697227d0b06255ece42a87062a11437ac97c7d" alt=""
remove files from staging area
staging area & working directory
data:image/s3,"s3://crabby-images/dda34/dda3488eb056461f9da7b3c5eb1f9fc45f52fd8b" alt=""
Collaboration
data:image/s3,"s3://crabby-images/18ad0/18ad0e3b6abe25f2c6539eb757b2ae260169f5ee" alt=""
Remote Repository Hosting
data:image/s3,"s3://crabby-images/76c8f/76c8f9f1af3c597ad67499b8c2dfe5509e1abc65" alt=""
data:image/s3,"s3://crabby-images/1872f/1872fcb336ee069573b9d20da4fa5fcba48638f3" alt=""
data:image/s3,"s3://crabby-images/dfeb7/dfeb7d5b785f7b8738a240c9d00488ea833e7db7" alt=""
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
data:image/s3,"s3://crabby-images/1872f/1872fcb336ee069573b9d20da4fa5fcba48638f3" alt=""
data:image/s3,"s3://crabby-images/97d29/97d29b3a8f3692286ede6d733c7d430097d1afc1" alt=""
data:image/s3,"s3://crabby-images/bfbe2/bfbe2a22687f860298086f30ed798a15e48f649c" alt=""
data:image/s3,"s3://crabby-images/dfeb7/dfeb7d5b785f7b8738a240c9d00488ea833e7db7" alt=""
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
data:image/s3,"s3://crabby-images/2ce37/2ce37939fa5e425da10d1b343d5b1d40ce86a3cd" alt=""
data:image/s3,"s3://crabby-images/786fc/786fcef4ce6daa108f9bdd0d5379477e78f1b2d2" alt=""
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
data:image/s3,"s3://crabby-images/76c8f/76c8f9f1af3c597ad67499b8c2dfe5509e1abc65" alt=""
data:image/s3,"s3://crabby-images/6b954/6b9545c475042b9d35cd6f45d9134393615f7fd5" alt=""
data:image/s3,"s3://crabby-images/fc7e1/fc7e1ad5ca34f712fdfcd8f3aad7b1b86222c632" alt=""
data:image/s3,"s3://crabby-images/fb45e/fb45ec1c43ef13e72c8703165e657172711c7a88" alt=""
data:image/s3,"s3://crabby-images/b79bd/b79bd7a8d0bf6440c5d165d26739dc4e710177b1" alt=""
Exclude files
local .gitignore:
In your git repo, create .gitignore file https://github.com/github/gitignore
global .gitignore:
$ git config --global core.excludesfile ~/.gitignore_global
Explicit repository excludes:
In your git repo, open .git/info/exclude
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
Workflows
1. Centralised Workflow
2. Features Branch Workflow
3. Gitflow Workflow
4. Forking Workflow
Just guidelines, you can mix & match
1. Centralised Workflow
data:image/s3,"s3://crabby-images/97db6/97db65e6c0c6522f53bccb2336a828fa9db93607" alt=""
data:image/s3,"s3://crabby-images/97db6/97db65e6c0c6522f53bccb2336a828fa9db93607" alt=""
data:image/s3,"s3://crabby-images/97db6/97db65e6c0c6522f53bccb2336a828fa9db93607" alt=""
data:image/s3,"s3://crabby-images/97db6/97db65e6c0c6522f53bccb2336a828fa9db93607" alt=""
data:image/s3,"s3://crabby-images/fc074/fc0742a4d5212e8039966010f1c1109ce6d0dea1" alt=""
data:image/s3,"s3://crabby-images/fc074/fc0742a4d5212e8039966010f1c1109ce6d0dea1" alt=""
data:image/s3,"s3://crabby-images/694b8/694b8aeb32553c0e43736be74713e7bca01ea7a0" alt=""
Syncing
$ git fetch <remote>
$ git fetch <remote> <branch>
$ git pull <remote>
$ git push <remote> <branch>
$ git push <remote> --all
$ git push <remote> --tags
data:image/s3,"s3://crabby-images/3b31d/3b31d40c42249f2db080fa42ce043cc50e2f735c" alt=""
2. Feature Branch Workflow
data:image/s3,"s3://crabby-images/0f033/0f033f1ebac4f11c2a65381df5eaf5cd57aefed8" alt=""
Pull / Merge Request
Branch
Develop a feature on a branch. Create a Pull-Request, to get reviewed
data:image/s3,"s3://crabby-images/1b69a/1b69a15aa2e7fbcb295adfc7447269f2fd0aff84" alt=""
data:image/s3,"s3://crabby-images/18e8a/18e8a9a81c8ea68a165371a4146668b91216a820" alt=""
data:image/s3,"s3://crabby-images/17c17/17c1701ab700037391d24ca2af5fe5313059b0a6" alt=""
data:image/s3,"s3://crabby-images/5ffad/5ffadb232acd5a60f8b6da0f74a946c34c091f38" alt=""
Discuss
Discuss and approve code changes
Merge
Merge the branch & optionally delete the branch
data:image/s3,"s3://crabby-images/95695/95695da38605f4805cb0219def041d94048be991" alt=""
3. Gitflow Workflow
Tagging
$ git tag
$ git tag -a v0.0.3 -m "release version 0.0.3"
$ git push --tags
$ git checkout v0.0.3
data:image/s3,"s3://crabby-images/785a2/785a2de5d5488a71d265e51c71d716a49cd59ee1" alt=""
list all tags
add a new tag
push the tag
checkout code at commit
4. Forking Workflow
data:image/s3,"s3://crabby-images/933d6/933d6fe78e0ae03270fd46b30f895cadfef40d0d" alt=""
data:image/s3,"s3://crabby-images/2572b/2572b8f29e1a148bebc74bde262083b725e3de2f" alt=""
Branching
Need to work on a feature that will take some time?
Time to branch out.
data:image/s3,"s3://crabby-images/ec7ee/ec7eeabc476f987ab564241e92b4151110ba5af0" alt=""
Branching
$ git checkout -b new_branch
$ git checkout master
$ git merge new_branch
$ git branch -d new_branch
Master
Pull-Request
1.
$ git branch meetup_attendance
$ git checkout meetup_attendance
$ git branch
$ git push origin meetup_attendance
data:image/s3,"s3://crabby-images/abae0/abae04479f4b6b4af41f0717af335282b6c89432" alt=""
OR $ git checkout -b meetup_attendance
2.
# Create a remote branch on Remote Server
$ git pull
$ git branch -r
$ git checkout online_attendance
$ git branch
$ git remote show origin
Branching
Removing Branch
$ git push origin :meetup_attendance
$ git branch -d meetup_attendance
$ git branch -D meetup_attendance
$ git remote prune origin
delete remote branch
delete local branch
clean up deleted remote branches
forcefully delete local branch
data:image/s3,"s3://crabby-images/2572b/2572b8f29e1a148bebc74bde262083b725e3de2f" alt=""
Merge vs Rebase
data:image/s3,"s3://crabby-images/fed7e/fed7ec9fc6b8e11f6aa8ae7c2a7071faee7eed9e" alt=""
Local branches
Extra merge commits are bad
Merge vs Rebase
Extra merge commits are bad
$ git fetch
$ git rebase
- Move all changes to master which are not in origin/master to a temporary area.
- Run all origin/master commits.
- Run all commits in the temporary are, one at a time.
- (no merge commits)
The golden rule of git rebase is to never use it on public branches.
Stashing & Cleaning
data:image/s3,"s3://crabby-images/248c9/248c9b9f1fe311ccb3306a26bd22fd7a4c43033a" alt=""
$ git stash $ git stash pop $ git stash list $ git stash drop
Temporary stores all modified tracked files
Restores the most recently stashed files
List all stashed changesets
Discard the most recently stashed changesets
Git for DevOps
data:image/s3,"s3://crabby-images/33043/33043485493e73b6622a68bed4d0d5dde5b6f4f4" alt=""
data:image/s3,"s3://crabby-images/97db6/97db65e6c0c6522f53bccb2336a828fa9db93607" alt=""
data:image/s3,"s3://crabby-images/c3459/c3459cfa7c979f8155fe6ca41e719c490cd1432a" alt=""
data:image/s3,"s3://crabby-images/c2684/c26847bb85133f35260d487d3a8406bb6a063c2f" alt=""
data:image/s3,"s3://crabby-images/1243c/1243c65f7c783479764657b2645e5ca687d22bc6" alt=""
data:image/s3,"s3://crabby-images/f9c26/f9c26a89f528d4c7d7b0db98051cabe72fa09a6b" alt=""
data:image/s3,"s3://crabby-images/879d1/879d1d981bc4c077c708ed0e378187b88f78ec77" alt=""
data:image/s3,"s3://crabby-images/fa660/fa6600c6c661575aec4e1857630cdace764d427a" alt=""
data:image/s3,"s3://crabby-images/a236e/a236eedb9260636173878310e6d12ac38c022134" alt=""
Dev
data:image/s3,"s3://crabby-images/744d1/744d14f3688b1549c32b9d659be6a01ae2cb51c1" alt=""
SCM
Build
Package Repo
Deploy
Test
Stage
Prod
data:image/s3,"s3://crabby-images/b45a4/b45a4e8b5bc4d10afeb908f2d66d3baad7712d32" alt=""
JIRA
Confluence
Slack
data:image/s3,"s3://crabby-images/8a089/8a08911df9fa1c9cdc6c4f3f901793734126eb96" alt=""
Automated build & Continuous Integration
data:image/s3,"s3://crabby-images/d72a8/d72a82cf7c134d9472a54081dae06751494a1b0d" alt=""
data:image/s3,"s3://crabby-images/bac39/bac39a070d0be9c46f6936807bebab5422f9826a" alt=""
Waffle
CI Friendly Git Repo
-
Avoid tracking large files in your repo
-
Use shallow clones for CI
-
Choose your triggers wisely
-
Stop polling, start hooking
$ git clone --depth 1 <repo_url>
data:image/s3,"s3://crabby-images/dda34/dda3488eb056461f9da7b3c5eb1f9fc45f52fd8b" alt=""
Github for Project Management
data:image/s3,"s3://crabby-images/62a68/62a680ddff6d98b799173c27bba3cac60989830d" alt=""
Add-on Feature on GitHub
data:image/s3,"s3://crabby-images/96549/965497bb6b1d93bd16f5d2d38e0e842f57599e0f" alt=""
data:image/s3,"s3://crabby-images/bbed0/bbed0db969dbda3d154b604d91a2fa34131c3d5b" alt=""
data:image/s3,"s3://crabby-images/48570/485701f4a94c97c563de578c0871dc8ae0aff580" alt=""