Trunk Based Development

🥜In a Nutshell🥜

How I Learned to Stop Worrying And

🐘Love the Trunk🐘

Or...

Dave Anderson

Brief Intro

  • Who's heard of Trunk Based Development before? ✋
  • All developers work on a single branch, committing multiple times per day
    • Requires good development practices

    • Drives Continuous Integration

    • Facilitates Continuous Deployment and Lean Experimentation

Many different workflows

  • 🌊Waterfall
  • 🐙Octopus Merge
  • 🌿Branch🌿per🌿feature🌿
  • 🌳Trunk based development

💖🌳-Based Benefits💖

  • Focus on quickly delivering great code and collaborating with peers rather than the process of shipping it
  • Used exclusively by major software development shops that need not be named

What is Trunk Based Development?

A source-control branching model, where developers collaborate on code in a single branch called ‘trunk’ *, resist any pressure to create other long-lived development branches by employing documented techniques, avoid merge hell, do not break the build, and live happily ever after.

-trunkbaseddevelopment.com

🌳 *AKA master

A source control branching model, where developers collaborate on code in a single branch

  • 📚In contrast to Gitflow or branch-per-feature workflows..

  • ✍️✍️✍️Commit directly on master (AKA trunk) with small and frequent changes

Resist any pressure to create other long-lived development branches

  • 🕑Create short lived branches for the purposes of code review or CI runs

  • ❌Promptly delete them when they are no longer needed (1-2 days, not weeks)

Easy to merge

  • 🛣️Small & frequent commits minimize merge conflicts, even for deeper refactors

Never break the build

  • ✔️🔍Each commit is atomic and includes tests that are run before merge, both locally and by CI

  • ❌↩️If tests fail, the work can be automatically rolled back so others can continue to work while a fix is pursued.

Live Happily Ever After

  • 🔀Avoid painstaking merges

  • ✨Encourage refactors on the go

  • ⏩Changes quickly made available for use and review by stakeholders and team members

  • 🔁Shorten feedback loop to make bug fixes and tweaks

  • 🌌Avoid scope creep and big bang releases

  • 😌Less cognitive load - get things DONE DONE quicker

Dealing with large & complex stories

  • 🔷▪️▪️By keeping story sizes small and breaking them down when possible
  • 🚩By using feature flags to switch off code that is not yet feature complete
  • 👁️By using techniques like branch by abstraction or strangulation 

Continuous Code Review

  • ⏲️Quick turnaround time to minimize time till useful code can be deployed or shared with team. “Tens of minutes” is “acceptable” More than an hour or two impacts cycle times.
  • 🙋‍♀️🙋‍♂️Pair programming also provides a mechanism for quick feedback and review of code and is often used rather than a Pull Request

Confidence in Testing

  • 🗺️TDD if possible, but..
  • 📐Follow the Test Pyramid
  • 🔭Strong production monitoring and alerting a bonus for Continuous Delivery

Cutting a Release

  • 🚒If following Continuous Delivery, possible to firehose commits to production
  • ↗️Otherwise, use release branches from trunk can be used. Any bug fixes performed in trunk and cherry-picked to the release branch

Happiness, revisited

  • 🔀Avoid painstaking merges

  • ✨Encourage refactors on the go

  • ⏩Changes quickly made available for use and review by stakeholders and team members

  • 🔁Shorten feedback loop to make bug fixes and tweaks

  • 🌌Avoid scope creep and big bang releases

  • 😌Less cognitive load - get things DONE DONE quicker

Questions?

  • 🤔
  • ⁉️
  • 🙋

Resources

Trunk Based Development: In a Nutshell

By Dave Anderson

Trunk Based Development: In a Nutshell

A brief overview of Trunk-based development and related practices.

  • 866