npm Release #128
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# npm packages release automation | |
name: npm Release | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: '0 12 1 * *' | |
permissions: | |
contents: read | |
# Cancels all previous workflow runs for pull requests that have not completed. | |
concurrency: | |
# The concurrency group contains the workflow name and the (target) branch name. | |
group: ${{ github.workflow }}-${{ github.head_ref || github.ref }} | |
cancel-in-progress: true | |
env: | |
PRODUCTION_REGISTRY_URL: https://wombat-dressing-room.appspot.com | |
LOCAL_REGISTRY_URL: http://localhost:4873 | |
GIT_AUTHOR_EMAIL: [email protected] | |
GIT_AUTHOR_NAME: googleforcreators-bot | |
GIT_COMMITTER_EMAIL: [email protected] | |
GIT_COMMITTER_NAME: googleforcreators-bot | |
jobs: | |
dry-run: | |
name: Dry-run release | |
runs-on: ubuntu-latest | |
timeout-minutes: 30 | |
# This step requires additional review | |
# See https://docs.github.com/en/actions/reference/environments | |
environment: Production | |
steps: | |
- name: Checkout | |
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 | |
- name: Setup Node | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 | |
with: | |
node-version-file: '.nvmrc' | |
cache: npm | |
- name: Install dependencies | |
run: npm ci | |
env: | |
PUPPETEER_SKIP_DOWNLOAD: true | |
- name: Setup Bun | |
uses: oven-sh/setup-bun@8f24390df009a496891208e5e36b8a1de1f45135 | |
with: | |
bun-version: latest | |
- name: Bundle packages | |
run: bun run workflow:bundle-packages | |
env: | |
NODE_OPTIONS: '--max_old_space_size=4096' | |
# Exact format here doesn't matter for the dry-run, it's gonna be done properly later on. | |
- name: Version bumps | |
id: version_bumps | |
run: npm version --no-git-tag-version --workspaces "0.1.$(date -u +%Y%m%d%H%M)" | |
# Set up a local npm registry with Verdaccio. | |
- name: Set up local registry | |
run: bun run local-registry:start | |
# Using Verdaccio | |
- name: Publish packages locally | |
run: npm --registry=$LOCAL_REGISTRY_URL --workspaces publish | |
# Undo the version bumps in Git. We only needed them for testing. | |
- name: Clean up local changes | |
run: git checkout . | |
# Verifies that packages can be installed without issues. | |
- name: Install published packages | |
run: | | |
PUBLIC_PACKAGES=$(jq -r 'select(.private == false) | .name' $(find packages -maxdepth 2 -name "package.json")) | |
TMPDIR=${TMPDIR-/tmp} | |
TMPDIR=$(echo $TMPDIR | sed -e "s/\/$//") | |
TEST_DIR=${TEST_DIR-$TMPDIR/packages-test} | |
mkdir $TEST_DIR | |
cd $TEST_DIR | |
npm init --yes | |
npm --registry=$LOCAL_REGISTRY_URL install $PUBLIC_PACKAGES | |
npm ls --depth 0 | |
- name: Stop local registry | |
run: bun run local-registry:stop | |
release: | |
name: Release | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write # for Git to git push | |
timeout-minutes: 20 | |
needs: [dry-run] | |
steps: | |
- name: Harden Runner | |
uses: step-security/harden-runner@f086349bfa2bd1361f7909c78558e816508cdc10 | |
with: | |
egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs | |
- name: Checkout | |
uses: actions/checkout@a5ac7e51b41094c92402da3b24376905380afc29 | |
with: | |
token: ${{ secrets.GOOGLEFORCREATORS_BOT_TOKEN }} | |
# See go/npm-publish | |
- name: Setup Node | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 | |
with: | |
node-version-file: '.nvmrc' | |
cache: npm | |
registry-url: ${{ env.PRODUCTION_REGISTRY_URL }} | |
scope: '@googleforcreators' | |
- name: Install dependencies | |
run: npm ci | |
env: | |
PUPPETEER_SKIP_DOWNLOAD: true | |
- name: Setup Bun | |
uses: oven-sh/setup-bun@8f24390df009a496891208e5e36b8a1de1f45135 | |
with: | |
bun-version: latest | |
- name: Bundle packages | |
run: bun run workflow:bundle-packages | |
env: | |
NODE_OPTIONS: '--max_old_space_size=4096' | |
# For the time being, using incremental versions like 0.1.202111302140 | |
# `npm version` updates all packages, even the ones we don't intend to publish. | |
# To address this, we undo the version change for private packages. | |
# We're doing the commit ourselves since we only need it later on and | |
# since committing doesn't work properly when using workspaces. | |
# See https://github.com/npm/cli/issues/4017 | |
- name: Version bumps | |
id: version_bumps | |
run: | | |
NEW_VERSION_RAW="0.1.$(date -u +%Y%m%d%H%M)"; | |
NEW_VERSION="v$NEW_VERSION_RAW" | |
npm version --no-git-tag-version --workspaces $NEW_VERSION_RAW | |
# Undo changes to all the private packages. | |
for package_file in ./packages/*/package.json; do | |
if [[ $(cat $package_file | jq '.private') == true ]]; then | |
git checkout --quiet $package_file | |
fi | |
done | |
# Updates the lock file. | |
npm install | |
git add packages/*/package.json | |
git add package-lock.json | |
echo "Committing version bump" | |
echo | |
git commit -m "Bumping npm packages version to $NEW_VERSION" | |
echo "Adding tags" | |
echo | |
# For every public package, this creates a tag in the form "<package>-v1234". | |
# Example: templates-v1234 | |
for package_file in ./packages/*/package.json; do | |
if [[ $(cat $package_file | jq '.private') == false ]]; then | |
package_name=$(basename $(dirname $package_file)) | |
echo "Adding tag: $package_name-$NEW_VERSION" | |
git tag "$package_name-$NEW_VERSION" | |
fi | |
done | |
echo "Commit details:" | |
echo | |
git status | |
git log -n 1 | |
echo "Added tags:" | |
echo | |
git tag --points-at HEAD | |
echo "Changed files:" | |
echo | |
git show --pretty=%gd --stat | |
git push origin main --tags | |
# Do the actual publishing to npmjs.com via Wombat Dressing Room. | |
- name: Publish packages to production | |
run: npm --registry=$PRODUCTION_REGISTRY_URL --workspaces publish --workspaces | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} |