data:image/s3,"s3://crabby-images/e9a9e/e9a9eb03c3ab09a7f7307e9bdea7774516e67ea5" alt=""
Mathieu Spillebeen
Enlightenment:
Git flow
Overview
1. The problem
2. The solution in theory
3. The practical solution
Why do we use git
PRO
- Open source
- Fast
- Decentralised
- Efficient
- Easy to learn
CONTRA
- Fear of branches
- Fear of merge conflicts
1. The problem
One branch fits all!
One-person linear approach
One-environment
Unreadable history
Occasional extra branches
data:image/s3,"s3://crabby-images/846a3/846a3a33ea3586e2ad292c543bdde0cdf8f32588" alt=""
2. The solution in theory
A set of guidelines .
You can still do everything.
Sanitised documented workflow.
No more explanation.
data:image/s3,"s3://crabby-images/38094/380948ac9897239995f16f584539e5318367a2e7" alt=""
2.1 The environments problem
data:image/s3,"s3://crabby-images/caa4a/caa4a1cedfe48abd5bb20d26c93467641b286cbd" alt=""
- Never ending main-branches
- Every commit ready for deployment
1 local environment + 2 remote environments
2.2 The purpose problem
2.2.1 You want to debug something on live or staging.
2.2.2 You are working on a tricky/new feature.
2.2.3 You are fixing feedback based on staging env.
2.2.4 You are quickly fixing a tiny bug on live.
data:image/s3,"s3://crabby-images/9b47d/9b47d94cafc2aafa03cab4ef2d547b786dc05f85" alt=""
data:image/s3,"s3://crabby-images/c6f00/c6f00ec5ba14b1ef04cf8ad1125cbe52b685f51c" alt=""
2.2.2 You are working on a tricky/new feature
- The first secondary branch: Feature-branch!
- No unfinished work for reviewers to see.
- No interference with other developers.
- No harm in trying stuff out.
data:image/s3,"s3://crabby-images/c6f00/c6f00ec5ba14b1ef04cf8ad1125cbe52b685f51c" alt=""
- Always on develop
- Delete the branch after finishing
- How to push to live?
data:image/s3,"s3://crabby-images/d8c24/d8c24e5161974781c452ea669492609dd9e8679d" alt=""
2.2.3 You are fixing feedback based on staging env.
- Controled pieces of code forming live-releases
- Release-branch!
- All the features that are included inside the release should be reviewed
data:image/s3,"s3://crabby-images/419a9/419a9062641cbfff75b2fc13076f08651712108b" alt=""
2.2.3 You are fixing feedback based on staging env.
- Choose the point in time.
- Periodical back-merges.
data:image/s3,"s3://crabby-images/edba6/edba6a8b1c567b46a313eaf851d621682bf96d68" alt=""
2.2.4 You are quickly fixing a tiny bug on live.
- The last secondary branch: hotfix-branch!
- For avoiding the entire control process.
- Only stuff that doesn't need reviewing.
data:image/s3,"s3://crabby-images/f0399/f0399099eab30f22b1559ef29d529137d568aa7c" alt=""
2.3 So what does this all mean?
- 2 main, 3 secondary braches
- A control system for developers, reviewers en clients.
- Live will (almost) never be broken
- Clear and enlightened history for easy debugging.
data:image/s3,"s3://crabby-images/74c0a/74c0a65507965e648eeaf4338f8a3873ef5a571d" alt=""
2.4 Tagging conventions
2.4 Naming conventions
Production branch: master
Development branch: develop
Feature branch prefix: feature/
Release branch prefix: release/
Hotfix branch prefix: hotfix/
Start to Git Flow
Further reading:
nvie.com/posts/a-successful-git-branching-model/
Get a free GUI for faster learning:
Questions before I procede?
3. The practical solution
BEFORE:
- Forgotten branches
- No clarity
- Scary releases
- Unclear merge conflicts
data:image/s3,"s3://crabby-images/3b8bf/3b8bfbd9b0f8fb752f4e823372a76b4ff513413c" alt=""
data:image/s3,"s3://crabby-images/ba5af/ba5afb48b398d72e3c8c3aec02e9795c4755305a" alt=""
3. The practical solution
AFTER:
- Clear history
- Easy releases
- Clear merge conflicts
data:image/s3,"s3://crabby-images/2a57e/2a57e40f7ec637a98bfd7801984efa6390a82f18" alt=""
data:image/s3,"s3://crabby-images/f3458/f34581fd42a43d0184054f2304472fbbc9e80f49" alt=""
Merge conflicts
Develop
data:image/s3,"s3://crabby-images/4b6d7/4b6d789ef9565d9f135143705713d5374561784c" alt=""
data:image/s3,"s3://crabby-images/fe879/fe879299117599c829940d05d2d053a0a1eb7774" alt=""
Feature
Merge solutions
data:image/s3,"s3://crabby-images/216f8/216f8a91dc0f4e482816b3097a01249c38a19f57" alt=""
data:image/s3,"s3://crabby-images/0e36f/0e36f08578ccf9a76f2468c1236fa3af3dd0e920" alt=""
Git Flow in Drupal
Drupal 6 & 7
Staging
data:image/s3,"s3://crabby-images/3d3af/3d3af423c9b5bf80aee967f948433ec6fc6e2de0" alt=""
data:image/s3,"s3://crabby-images/50222/50222482306d72e27f5dc0bc7deac9d2f716abf4" alt=""
data:image/s3,"s3://crabby-images/35129/351291aea6b6ec0b9626e87786583c9441c97ed6" alt=""
Live
data:image/s3,"s3://crabby-images/3d3af/3d3af423c9b5bf80aee967f948433ec6fc6e2de0" alt=""
data:image/s3,"s3://crabby-images/50222/50222482306d72e27f5dc0bc7deac9d2f716abf4" alt=""
Features
Features
data:image/s3,"s3://crabby-images/35129/351291aea6b6ec0b9626e87786583c9441c97ed6" alt=""
Git Flow in Drupal
Drupal 8
Staging
data:image/s3,"s3://crabby-images/3d3af/3d3af423c9b5bf80aee967f948433ec6fc6e2de0" alt=""
data:image/s3,"s3://crabby-images/50222/50222482306d72e27f5dc0bc7deac9d2f716abf4" alt=""
data:image/s3,"s3://crabby-images/35129/351291aea6b6ec0b9626e87786583c9441c97ed6" alt=""
Live
data:image/s3,"s3://crabby-images/3d3af/3d3af423c9b5bf80aee967f948433ec6fc6e2de0" alt=""
data:image/s3,"s3://crabby-images/50222/50222482306d72e27f5dc0bc7deac9d2f716abf4" alt=""
Config
manager
data:image/s3,"s3://crabby-images/35129/351291aea6b6ec0b9626e87786583c9441c97ed6" alt=""
Config
manager
Scalable !== Fast
Full blown structure is great for big projects
data:image/s3,"s3://crabby-images/a9343/a9343563ca1ad5f304fc14473cc26eb26e12772b" alt=""
data:image/s3,"s3://crabby-images/b09bf/b09bf5ddf9748052ca6a3eae3ca3df9171d956d4" alt=""
No reviewer
data:image/s3,"s3://crabby-images/67a5c/67a5c163feb0144260d204c3ee1974af0f4df998" alt=""
if (FE == 1 && BE == 1)
FE = mergers
BE = branchers
data:image/s3,"s3://crabby-images/deb26/deb2657922286e0db828ddbbf6135e07907746b8" alt=""
If (FE > 1 || BE > 1)
Because now there is a bigger chance of people working in the same lines of code
Put it all in context
Remember the one branch fits all solution?
Git should stay in the background
Git flow is used on every scale, but is experienced as slow on small projects.
Using Full blown Git Flow on small projects is like putting everything in features for small projects.
Conclusion
Adapt Git Flow to your own needs.
It makes sure developers think, before they create.
There are a couple of Git workflows too choose from:
atlassian.com/git/tutorials/comparing-workflows
data:image/s3,"s3://crabby-images/846a3/846a3a33ea3586e2ad292c543bdde0cdf8f32588" alt=""
Questions
@mathieuSpil
mathieu.spillebeen@gmail.com
data:image/s3,"s3://crabby-images/e2f75/e2f7576a4f22a457452f86c1d1a2df4f29ee0bbd" alt=""
ENLIGHTENMENT: GIT FLOW
By Mathieu Spillebeen
ENLIGHTENMENT: GIT FLOW
Drupalcamp Belgium presentation about the concept of Git Flow
- 1,979