kitchen-sink/.github/workflows/release.yml
2026-04-28 18:51:55 -07:00

163 lines
5.2 KiB
YAML

name: Release
on:
release:
types: [published]
workflow_dispatch:
inputs:
tag:
description: Release tag to publish, for example v0.1.0
required: true
type: string
permissions:
contents: read
id-token: write
jobs:
validate:
runs-on: ubuntu-latest
outputs:
package_name: ${{ steps.verify.outputs.package_name }}
package_version: ${{ steps.verify.outputs.package_version }}
tag_name: ${{ steps.verify.outputs.tag_name }}
npm_tag: ${{ steps.verify.outputs.npm_tag }}
npm_already_published: ${{ steps.npm_exists.outputs.already_published }}
tarball_name: ${{ steps.pack.outputs.tarball_name }}
steps:
- name: Checkout code
uses: actions/checkout@v6
with:
fetch-depth: 0
ref: ${{ inputs.tag || github.event.release.tag_name }}
- name: Setup Node.js
uses: actions/setup-node@v6
with:
node-version: "22.14.0"
registry-url: "https://registry.npmjs.org"
- name: Setup npm
run: npm install -g npm@11.12.1
- name: Validate release tag matches package version
id: verify
env:
TAG_NAME: ${{ inputs.tag || github.event.release.tag_name }}
run: |
PACKAGE_NAME="$(node -p "require('./package.json').name")"
PACKAGE_VERSION="$(node -p "require('./package.json').version")"
NPM_TAG="latest"
if [[ "$PACKAGE_VERSION" == 0.0.* ]]; then
NPM_TAG="verification"
fi
if [ -z "$TAG_NAME" ]; then
echo "tag input is required for workflow_dispatch, and release.tag_name is required for release runs."
exit 1
fi
EXPECTED_TAG="v${PACKAGE_VERSION}"
if [ "$TAG_NAME" != "$EXPECTED_TAG" ]; then
echo "Tag/version mismatch."
echo "Expected tag: $EXPECTED_TAG"
echo "Actual tag: $TAG_NAME"
echo "package.json version: $PACKAGE_VERSION"
exit 1
fi
echo "package_name=$PACKAGE_NAME" >> "$GITHUB_OUTPUT"
echo "package_version=$PACKAGE_VERSION" >> "$GITHUB_OUTPUT"
echo "tag_name=$TAG_NAME" >> "$GITHUB_OUTPUT"
echo "npm_tag=$NPM_TAG" >> "$GITHUB_OUTPUT"
- name: Check if this version is already published to npm
id: npm_exists
run: |
if npm view "${{ steps.verify.outputs.package_name }}@${{ steps.verify.outputs.package_version }}" version >/dev/null 2>&1; then
echo "already_published=true" >> "$GITHUB_OUTPUT"
else
echo "already_published=false" >> "$GITHUB_OUTPUT"
fi
- name: Install dependencies
if: steps.npm_exists.outputs.already_published != 'true'
run: npm ci
- name: Run checks
if: steps.npm_exists.outputs.already_published != 'true'
run: npm test
- name: Run runtime inspector
if: steps.npm_exists.outputs.already_published != 'true'
run: npm run plugin:inspect:runtime
- name: Verify package payload
if: steps.npm_exists.outputs.already_published != 'true'
run: npm run pack:check
- name: Pack npm release artifact
id: pack
if: steps.npm_exists.outputs.already_published != 'true'
run: |
TARBALL_NAME="$(npm pack --json | jq -r '.[0].filename')"
echo "tarball_name=$TARBALL_NAME" >> "$GITHUB_OUTPUT"
- name: Upload npm release artifact
if: steps.npm_exists.outputs.already_published != 'true'
uses: actions/upload-artifact@v7
with:
name: npm-release-tarball
path: ${{ steps.pack.outputs.tarball_name }}
if-no-files-found: error
- name: Report already-published release state
if: steps.npm_exists.outputs.already_published == 'true'
run: |
echo "Skipping publish: ${{ steps.verify.outputs.package_name }}@${{ steps.verify.outputs.package_version }} is already published to npm."
publish-npm:
needs: validate
if: needs.validate.outputs.npm_already_published != 'true'
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
steps:
- name: Setup Node.js
uses: actions/setup-node@v6
with:
node-version: "22.14.0"
registry-url: "https://registry.npmjs.org"
- name: Setup npm
run: npm install -g npm@11.12.1
- name: Download npm release artifact
uses: actions/download-artifact@v8
with:
name: npm-release-tarball
path: ./release-artifacts
- name: Publish to npm
run: |
npm publish "./release-artifacts/${{ needs.validate.outputs.tarball_name }}" --access public --tag "${{ needs.validate.outputs.npm_tag }}"
publish-clawhub:
needs: validate
permissions:
contents: read
id-token: write
uses: openclaw/clawhub/.github/workflows/package-publish.yml@main
with:
dry_run: false
ref: ${{ needs.validate.outputs.tag_name }}
version: ${{ needs.validate.outputs.package_version }}
source_ref: refs/tags/${{ needs.validate.outputs.tag_name }}
secrets:
clawhub_token: ${{ secrets.CLAWHUB_TOKEN }}