question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Move to a single branch release flow on "main" branch

See original GitHub issue

As @haworku and @eamahanna witnessed, our current release flow is flawed:

  • Merging the release branch into master requires that we also have to keep develop up-to-date with the release branch changes. This means an extra PR that must be approved
  • Since we’ve transitioned to using squash & merge on this repo exclusively, the workflow of develop -> release branch -> master -> develop breaks with a linear commit history, and also results in a loss of commit history since release PRs are squashed on master

My suggestion is the following:

  • Deprecate the current master branch and use only one main branch for active development and stable versions (naming can be TBD)
  • Stable versions will always be accessible via their associated tag.
    • Version tags should be checked out if the code at a specified version needs to be examined, or when making maintenance fixes.
  • The new release flow will be: main branch -> create release branch, update version/changelog -> approve release branch PR -> merge release into main branch -> tag and publish

Pros:

  • Removes extra step of merge into master and also into develop
  • Removes potential confusion of which branch a release PR should be based off
  • Keeps a cleaner commit history using squash & merge (the release branch merges will always just reflect the chore: release commit, which should always only be the new version number and changelog updates)
  • Release hotfixes should be made directly off of develop (and merged back into it)

Cons:

  • From the time of creating the release branch, all other merges to develop should be prevented until the release has been completed. Otherwise we risk publishing a release that has unaccounted-for changes.
    • Mitigation: I would argue that right now, this project is small enough that we can mitigate that from happening with good team communication. Release PRs should take priority over any other PR reviews, and anyone issuing a new release can communicate via Slack that no PRs should be merged until it’s completed.
    • Mitigation: if new work does get merged in while a release PR is open, it can be resolved by requiring release-* branches always require being up to date with their base branch before being merged (this is a Github branch protection setting)

Issue Analytics

  • State:closed
  • Created 3 years ago
  • Comments:8 (8 by maintainers)

github_iconTop GitHub Comments

2reactions
DanielMiller-agile6commented, Jun 8, 2020

Just a suggestion, but here is another branching strategy I’ve used in the past that has worked pretty well and helped simplify things on a few projects. I haven’t used it for a component library before, but might be worth considering: http://releaseflow.org/

1reaction
eamahannacommented, Jun 1, 2020

I think this makes sense given it reduces the overall complexity with releases. I would just want to make sure the release documentation reflects that you need to make a PSA to the react-uswds channel when doing a release (just to make sure this doesn’t get overlooked).

Read more comments on GitHub >

github_iconTop Results From Across the Web

Gitflow release branch process from start to finish example
After the “git flow release finish” command runs, the release branch should be deleted and a new Git tag exists in the repository....
Read more >
Gitflow Workflow | Atlassian Git Tutorial
Instead of a single main branch, this workflow uses two branches to record the history of the project. The main branch stores the...
Read more >
Release Flow: How We Do Branching on the VSTS Team
Instead, we release our master branch every sprint by creating a branch for each release. When we need to bring hotfixes into production,...
Read more >
Don't Fear the Repo: Enhanced Git Flow Explained - Toptal
Release and hotfix branches require “double merging”—once into main, then into develop. At times you can forget to do both. You can make...
Read more >
Git Branching Strategies vs. Trunk-Based Development
A release branch can be either short-lived or long-lived depending on the strategy. In either case, the release branch reflects a set of...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found