When a package contains sufficient changes to justify a release to NPM, follow these instructions to create a new release from the monorepo.
Below are instructions for releasing using Github Workflows (recommended) and the command line. When releasing packages for the first time, release from the command line.
In order to prepare a package for release, a changelog will need to be compiled along with an appropriate version bump.
- Visit the monorepo Action Prepare Package Release workflow. Click the "Run workflow" button.
- Select the branch you'd like to release from. Typically, this would be
trunk
. You can also choose which packages to prepare for release by supplying them as comma separated values in the input box. To loop through all packages, simply leave the-a
flag. Packages that don't have any changes will be skipped and left as is.
- Once the action has finished, check open pull requests for a pull request generated by Github Actions Bot. This pull request should include version bumps and changelog changes for applicable packages. Approve and merge the pull request once checks pass.
- Release the packages to NPM by kicking off another workflow. The Packages Release workflow has the same inputs as the prepare workflow. Be sure to release from the same branch and select the same packages to release.
- Confirm the package has been updated by visiting NPM. For example see https://www.npmjs.com/package/@woocommerce/components. Note: it may take several minutes after a release for the update to be reflected on NPM.
- At monorepo root, run the following command to prepare all packages. Instead of the
-a
flag, you can pass in a list of packages separated by commas.
./tools/package-release/bin/dev prepare -a
When making an initial release for a new package, pass the --initial-release
flag to signify a new release for a new package.
- Create a pull request with the resulting changes and merge it.
See more about the prepare script using ./tools/package-release/bin/dev publish --help
.
-
Pull down the latest commits from Github.
-
Run the release script from monorepo root, first as a dry run.
When making an initial release for a new package, pass the --initial-release
flag to signify a new release for a new package.
./tools/package-release/bin/dev publish -a --dry-run
- Run the release for real this time.
./tools/package-release/bin/dev publish -a
See more about the publish script using ./tools/package-release/bin/dev publish --help
.