<!-- background: #fff -->
<!-- color: #000 -->
<!-- font: frutiger -->
# "Overkilling" Your Git Repo with Gitflow
by Stephon Harris
<script>
Hi! I'm Stephon out of the DC Office and today I'm going to tell you abut managing your source-controlled workflow with Gitflow.
</script>
***
# Bad workflows need to die
data:image/s3,"s3://crabby-images/a0e5d/a0e5dd13b9b56a649c4f3b0d61d950c15deee113" alt="bad-git" data:image/s3,"s3://crabby-images/c9eb9/c9eb96cdf8bf4965533f850db26c9e87ba3e364d" alt="bad"
You need a branching strategy to give your projects life
<script>
Managing the flow of code can grow scary using Git when you have a plethora of branches and convoluted merges. Gitflow is a branching model that is collaborative, scalable, and sustainable.
</script>
***
# Wait, But Why?
- Organize code for development and production-ready stages
- Provide workflow for integrating changes
- Parallel development of features
- Continuously deliver through releases and hotfixes
<script>
Gitflow wrangles up commits and merges with a clear and formal workflow for promoting production-ready code, and separating the development of new features, while still allowing for breakfixes to be made.
</script>
***
# OK, How?
data:image/s3,"s3://crabby-images/9a716/9a71609fb99ccb277ba301818d1ba6192036d93b" alt="gitflow"
<script>
There's a simple methodology behind this madness. Just study this image and you've got it! Just kidding, I'll walk you through how each of these branches are used.
</script>
***
# So there are Main Branches
data:image/s3,"s3://crabby-images/ff18f/ff18f28b51ecee4e9c54e8fcf943d535290b661b" alt="master"
data:image/s3,"s3://crabby-images/d8a8a/d8a8aa27395b0e5fef1be33a290e321c1e38dad4" alt="develop"
- Exist for the life of the project
- **Develop** contains work in progress
- **Master** contains production releases
<script>
Develop and Master are the two main branches. The Develop branch is for the code you're working to release. The Master branch is for the code you have released. These branches will exist for the life of the project. You don't ever commit directly to these branches, but rather merge in code.
</script>
***
# ...and Developmental Branches
data:image/s3,"s3://crabby-images/2fd82/2fd82efe89335d2c620e8bc43fa8b2af3c68d8bf" alt="Features"
data:image/s3,"s3://crabby-images/c0344/c0344ba61e436dd249b5c7c66cd5c4f949a148be" alt="Release"
data:image/s3,"s3://crabby-images/44f82/44f82ece46e25a19a71a7322491b3cbe01672f80" alt="Hotfix"
- Exist until merged into develop or release branches, or abandoned
- **Feature** contains developmental new features
- **Release** contains prepared releases from **Develop**
- **Hotfix** contains production fixes
<script>
The three branches you actually do work and commit to are feature branches, release branches, and hot-fixes. Feature branches are for developing as many new features as you'd like. Feature branches promote code to the Develop branch. Release branches, are for when you're ready to promote code from the Develop branch to Master for production. Making changes on the release branch is only for minor tweaks and release notes. And then there are hot-fixes that are for squashing any bugs and making minor changes that need to go directly to production code, and - most importantly - are not a new feature. When code is promoted to Develop and/or Master, the commits are integrated into the main branches and then the developmental branch is deleted. If you decide to abandon any changes before merging them into one of the main branches you can delete that developmental branch and continue to develop without having to back out of any changes.
</script>
***
# What?
\*<\sigh>\*
To put it plain and simple:
<script>
I know that can be a lot to take in so let me break it down for you.
</script>
***
# Start a feature -> Do some work -> Finish feature = Develop has new feature
data:image/s3,"s3://crabby-images/29a0c/29a0c4f7cfdd0cbd7803da3117d1ffdf5af33ddb" alt="feature"
<script>
Look at it this way. These gold circles represent commits and the grey circles represent merges. You start this flow by creating a feature, then working on it, and finally integrating that feature back into the develop branch or abandoning it.
</script>
***
# Create a release -> Tweak and write release note -> Finish Release = Production and Develop has new release
data:image/s3,"s3://crabby-images/f79f3/f79f3fc6001506050a842cb89e19cb1e26428831" alt="release"
<script>
When you're code is solid and you're ready to release it to the world, you create a release branch, add in minor changes and any release notes, and then it's merged into the develop and master branches.
<script>
***
# Create a hotfix -> Correct some code -> Finish hotfix = Production and Develop have hotfix
data:image/s3,"s3://crabby-images/8d799/8d79998d7ba114befe34d2a6b5a59935b0f65a79" alt="hotfix"
<script>
If there are any breakfixes that need to be made, you start a hotfix, make the code changes and then it's merged into the main branches.
</script>
***
# Repeat.
<script>
And this beautiful cycle is repeated for eternity, or at least for the life of your project.
</script>
***
# Demo
## Gitflow_init - Source Tree
1. Initialize & First commit
2. Create Feature
## Gitflow CLI
git flow init
git flow feature start SolarSystem
git flow feature finish SolarSystem
## Gitflow_feature - Source Tree
3. Create a release
4. Demonstrate how a release is merged into master and develop
5. Create a hot-fix
<script>
I'd like to now show you git flow in action
</script>
***
# Keep in Mind
- Developmental branches are given a respective naming convention (e.g. **feature**/Neptune, **release**/10000000, **hotfix**/pluto)
- Anything that goes to production is tagged (e.g. v1.0)
- Rebase when finishing **Feature** to keep **Develop** commit history linear and clean
- You can use [Git Hooks](https://github.com/jaspernbrouwer/git-flow-hooks) to automate naming tags/versions
<script>
Some things you may want to remember. There is a naming convention associated with branches and as you create new features, releases and hotfixes, they will take on their respective prefix. Production-level code in master is tagged. After finishing a feature, I suggest rebasing to keep your code pristine. Once you've found your gitflow groove, you can even automate tag numbers being bumped and specifying tag messages through git hook scripts.
</script>
***
# Woah!
data:image/s3,"s3://crabby-images/fe948/fe948cac04162820256924e8e5ee7e3b239f3018" alt="glitter-toss"
*You're welcome!*
<script>
Yea, Gitflow is pretty awesome and it makes your code play nice with others and more importantly helps you and your team release code quicker and cleaner, just how coding should be. Any questions?
</script>
***
# References
<script>
Attached is a reference to more material on Gitflow and how to set it up on your computer for a CLI and SourceTree.
</script>
- Gitflow's Branching Model Strategy- http://nvie.com/posts/a-successful-git-branching-model/
- Gitflow SourceTree- https://blog.sourcetreeapp.com/2012/08/01/smart-branching-with-sourcetree-and-git-flow/
- Gitflow CLI- https://github.com/nvie/gitflow
- Continuous Delivery & Gitflow- https://www.atlassian.com/continuous-delivery/continuous-delivery-workflows-with-feature-branching-and-gitflow
- Git Hooks- https://github.com/jaspernbrouwer/git-flow-hooks
- Glitter Toss- http://i.giphy.com/xTiTnEHBh7qapyuvwQ.gif