Skip to content

Release Process

Maicon Diniz Filippsen edited this page Sep 18, 2018 · 7 revisions

This page describes how we use branches and tags with every new release.

Considering all commits added to master branch are submitted via pull requests and properly reviewed, the master branch is expected to always be working.
master can also be referred to as the current version. The latest stable version is the latest version listed in the Releases section in GitHub (also accessed via git tag command).

Versioning rules

<MAJOR>.<MINOR>.<PATCH>
X.Y.Z
  • Patch (Z): only contains solved issues labelled as bugs
  • Minor (Y): contains solved issues labelled as features
  • Major (X): marks a big changeset when incompatible modifications or additions occur

Simplified method (currently in use)

  1. Bump version in master branch according to versioning rules. ./bump_version.sh "X.Y.Z"

  2. Tag the master branch according to versioning rules.

git tag -a X.Y.Z -m "Version X.Y.Z"
git push origin X.Y.Z
  1. Build from the latest tag

  2. Deploy the latest build

  3. New bugs and features are resolved on the next release

Release branches (for later reference)

  1. During the final countdown, a release branch is created: release/1.10.
  2. Superblocks Lab is built from the release/1.10 branch and released into https://lab-beta.superblocks.com
  3. Superblocks Lab is functionally and smoke tested with a build from that branch.
  4. Any critical issues should have fixed delivered to both master and release/1.10 and properly verified with step 2.
  5. When there are no more additional critical issues, a release tag 1.10.0 is created.
  6. Superblocks Lab is built from the 1.10.0 tag and shipped to customers.
  7. Any further recovery builds should be from commits on the release/1.10 branch and patch versions should be used: 1.10.1, 1.10.2, etc.