The release process describes creating a release on Github. Each release consists of a new tag and assets which are builds for various environments but not only.
The process is automated and, even though it's possible to run manually, should always be triggered using our Jenkins job.
We use semver but as we do not have a stable version yet, it's a bit skewed.
We use 0
as the MAJOR version and bump only MINOR when there are breaking changes and PATCH when there are no breaking changes.
- Go to Jenkins job,
- Leave "RELEASE" unchecked and use your branch name.
After successful build, open it (https://ci.status.im/job/status-go/job/manual/$BUILD_ID/) in a browser. Artifacts will have a random ID, for example status-go-android-181221-143603-5708af.aar
, means that 181221-143603-5708af
is a version you can use in status-mobile.
TODO: create a script that can do that instead of manual work.
- Checkout a release branch you want to release from (release branches have names like
release/0.X
), - Cherry-pick a commit you want to include OR merge
develop
branch, - Bump
Y
(0.X.Y
) in the current version (VERSION
file), - Commit and push the change to
release/0.X
branch, - Go to Jenkins job, select "RELEASE" and use
release/0.X
branch name.
TODO: create a script that can do that instead of manual work.
- Merge your PR to
develop
branch, - Pull
develop
branch locally, - Bump
X
, resetZ
to0
and commit todevelop
with a message "Bump version to 0.X.Y", - Checkout a new branch
release/0.X
, - Remove
-beta.Z
suffix from the current version (VERSION
file), - Commit and push the change,
- Go to Jenkins job, select "RELEASE" and use
release/0.X
branch.