-
Notifications
You must be signed in to change notification settings - Fork 15
Labels
Description
Motivation
Our current release process is for a core maintainer to run npx nx release --yes in main branch (requires npm login and GITHUB_TOKEN in .env).
We've previously spent quite a lot of effort in releasing via GitHub Actions, but never quite got it working reliably. A partially broken release is complex to recover from, so running a command locally proved to be more practical.
But our current release process relies too much on one person, and doesn't allow us to secure npm publishing via provenance or trusted publishing.
Acceptance criteria
- run
nx releaseon push tomainbranch- release is skipped if no user-facing commits (
feat,fix,perf) were pushed
- release is skipped if no user-facing commits (
- GitHub Actions is configured as a trusted publisher
- no long-lived npm token is used
- Node needs to be updated to
24.5or higher (npmCLI version11.5.1or higher)
-
nx releaseruns all steps as when we run it manually, i.e.:- skip if there's nothing to release
- generate next version tag from commit history
- update changelog
- push tagged release commit
- build all publishable packages
- publish packages to npm
- create GitHub release with description from changelog
BioPhoton