When working on large projects, there’s a natural tendency to create a branch and start hacking away. When you have a separate branch like this, thi

Trunk-based development: Increasing engineering velocity and reducing frustration

submited by
Style Pass
2025-01-16 09:00:05

When working on large projects, there’s a natural tendency to create a branch and start hacking away. When you have a separate branch like this, things tend to balloon. As a developer, you get the urge to refactor all sorts of adjacent things that’ll make your changes cleaner. Before you know it, the scope of your branch is significantly larger than you had originally planned.

Even if you stay vigilant about the scope of your branch, you often run into frustrating merge conflicts that can introduce new errors or accidentally roll back other people’s changes if you’re not careful. Scoping features into the smallest possible size that makes sense for the end-user is good practice, but even when doing so, you often have new features or refactoring that can take several weeks or even months to finish.

The longer your branch has been living on its own, the harder it is to merge back into the main branch when the time comes because the main branch (“trunk”) has had plenty of changes happen since then.

Leave a Comment