For a monorepo using an "independent" versioning strategy, the tool needs to know two things:
- Which packages you want to release and how to set the version for each package.
- Whether or not you are creating a backport release as opposed to an "ordinary" release.
Typically, a new release will follow the most recent release (that is, the changes within the release are applied to the code in the most recent release). We call this an ordinary release.
Start by running:
create-release-branch
The tool will generate a "release specification", which is a YAML file, and open it in your editor (or, if it cannot detect an appropriate editor, output the path to the file for you to open yourself). This file represents an object that contains one property, packages
. The value of this property is also an object, where:
- Each property is the name of the workspace package you want to release.
- Each value specifies the new version the package should receive. This can either be:
major
if you want to bump the major part of the current version (e.g., if the current version is 1.0.0, then the release version would be 2.0.0).minor
if you want to bump the minor part of the current version (e.g. if the current version is 1.0.0, then the release version would be 1.1.0).patch
if you want to bump the patch part of the current version (e.g. if the current version is 1.0.0, then the release version would be 1.0.1).- An exact version such as
1.2.3
.
The packages
object will be populated with all of the packages that have changed since the previous release. You should not change this list.
A typical release spec, once edited, might look like this:
packages:
"@metamask/base-controller": major
"@metamask/controller-utils": minor
"@metamask/transaction-controller": patch
"@metamask/assets-controllers": 1.2.3
Once you've filled out the release spec, save and close it, and the tool will continue. (Or, if the tool couldn't detect your editor and you had to edit the file manually, then run create-release-branch
again to resume).
At this point, the tool will:
- Calculate a new release version by incrementing the "ordinary" (first) number of the current version, then set the
version
of the root package to this new version. - Go through each workspace package specified, and:
- Calculate a new version of the package that you specified in the release spec, then set the
version
of the package to this new version. - Read the Git history of the repo to extract the names of the commits which have made any changes to any files within the package since the Git tag that corresponds to the current version of the package.
- Add a new section to the changelog for the package which is titled by the release version and which lists the commits gathered.
- Calculate a new version of the package that you specified in the release spec, then set the
- Commit the changes to a new branch called
release/<release-version>
, where<release-version>
is the version calculated in step one (e.g.release/5.0.0
), then switch to that branch.
Sometimes you will need to create a release which contains a change, such as an important fix, to a pre-existing release. We call this a backport release.
The process for creating a backport release works the same as an ordinary release, except before you run the tool, you will switch to a branch that represents an "alternative timeline" based off a past version (for instance, you might have previously cut a branch that continues the 1.x line of the project, even though the latest version is 2.x).
Note It's necessary to be on another branch and not the main line, because
create-release-branch
uses the version of packages as they exist on the current branch, and not the latest published versions, to determine the release version and to populate changelogs correctly.
Once on this branch, run:
create-release-branch --backport
In this case, the new release version will be calculated by incrementing the "backport" (second) number of the current version, but the versions and changelogs of workspace packages will still be updated according to the release spec.