Files
backstage/docs/publishing.md
T
Patrik Oldsberg 163b4d2d33 docs/publishing.md: review fixes
Co-authored-by: Fredrik Adelöw <freben@gmail.com>
Co-authored-by: Johan Haals <johan.haals@gmail.com>
Signed-off-by: Patrik Oldsberg <poldsberg@gmail.com>
2022-01-12 13:32:32 +01:00

3.0 KiB

npm

npm packages are published through CI/CD in the .github/workflows/master.yml workflow. Every commit that is merged to master will be checked for new versions of all public packages, and any new versions will automatically be published to npm.

Creating a new release

Releases are handled by changesets and trigger whenever the "Version Packages" PR is merged. This is typically done every Thursday around noon CET.

Emergency Release Process

This emergency release process is intended only for the Backstage maintainers.

For this example we will be using the @backstage/plugin-foo package as an example and assume that it is currently version 1.5.0 in the master branch.

In the event of a severe bug being introduced in version 1.5.0 of the @backstage/plugin-foo released in the 2048-01-01 release, the following process is used to release an emergency fix as 1.5.1:

  • Identify the release that needs to be patched, in this case we're fixing a broken release, so it would be the most recent one, 2048-01-01. In the event of a backported security fix, the release that has the last published version of each major version of the package should be the one patched.

  • Make sure a patch branch exists for the release that is being patched. If a patch already exists, reuse the existing branch. The branch must always be named exactly release-<release>-patch.

    git checkout release-2048-01-01
    git checkout -b release-2048-01-01-patch
    git push --set-upstream origin release-2048-01-01-patch
    
  • With the release-2048-01-01-patch branch as a base, create a new branch for your fix. This branch can be named anything, but the following naming pattern may be suitable:

    git checkout -b ${USER}/release-2048-01-01-emergency-fix
    
  • Apply fixes and create a new patch changeset for the affected package, then commit these changes.

  • Run yarn release in the root of the repo in order to convert your changeset into package version bumps and changelog entries. Commit these changes as a second "Generated release" commit.

  • Create PR towards the base branch (release-2048-01-01-patch) containing the two commits.

  • Review/Merge the PR into release-2048-01-01-patch. This will automatically trigger a release.

  • Make sure the same fix is applied in master before the next release, and create an appropriate changeset for that as well. In the changeset towards master you should refer back to all patch releases that also received the same fix. Also be sure to update .changeset/patched.json in the same PR to make sure that future releases of the packages are bumped accordingly:

    {
      "currentReleaseVersion": {
        "@backstage/plugin-foo": "1.5.1"
      }
    }