Skip to content

Update draft features (#2472) #875

Update draft features (#2472)

Update draft features (#2472) #875

name: Publish web-features@next
on:
push:
branches:
- "main"
paths:
- features/**
- groups/**
- packages/web-features/**
- snapshots/**
- index.ts
- scripts/build.ts
permissions:
contents: write
env:
package: "web-features"
package_dir: "packages/web-features"
dist_tag: "next"
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version-file: .node-version
cache: npm
- run: npm ci
- run: npm test
publish:
if: github.repository == 'web-platform-dx/web-features'
runs-on: ubuntu-latest
needs: "test"
steps:
- uses: actions/checkout@v4
- name: Get timestamp and short hash
id: timestamp_and_hash
run: |
echo "TIMESTAMP=$(date +'%Y%m%d%H%M%S')" >> $GITHUB_OUTPUT
echo "SHORT_HASH=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
- uses: actions/setup-node@v4
with:
node-version-file: .node-version
cache: npm
registry-url: "https://registry.npmjs.org"
- run: npm ci
- run: npm run build
- run: npm run build:extended
- name: Get package.json version
id: version
run: echo "VERSION=$(npm version --json | jq --raw-output '.["${{ env.package }}"]')" >> $GITHUB_OUTPUT
working-directory: ${{ env.package_dir }}
- run: npm install
working-directory: ${{ env.package_dir }}
- run: npm version --no-git-tag-version "$VERSION-dev-$TIMESTAMP-$SHORT_HASH"
# The version string template is: <package.json version>-dev-<timestamp>-<commit-hash>
# Why not use SemVer build metadata with a plus sign for some of this?
# Because npm completely ignores it. 😒
working-directory: ${{ env.package_dir }}
env:
VERSION: ${{ steps.version.outputs.VERSION }}
TIMESTAMP: ${{ steps.timestamp_and_hash.outputs.TIMESTAMP }}
SHORT_HASH: ${{ steps.timestamp_and_hash.outputs.SHORT_HASH }}
- if: ${{ env.NODE_AUTH_TOKEN }}
run: npm publish --tag ${{ env.dist_tag }}
working-directory: ${{ env.package_dir }}
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
- name: Set existing release to draft
run: gh release edit --draft "$TAG"
env:
GH_TOKEN: ${{ github.token }}
TAG: ${{ env.dist_tag }}
- name: Update the tag
run: |
git config user.name "github-actions[bot]"
git config user.email "41898282+github-actions[bot]@users.noreply.github.com"
git tag --force "$TAG"
git push --force origin "$TAG"
env:
GH_TOKEN: ${{ github.token }}
TAG: ${{ env.dist_tag }}
- name: Publish pre-release on GitHub
run: |
gh release edit \
--verify-tag \
--title "$PACKAGE@$TAG" \
--notes "$NOTES" \
--prerelease \
--draft=false \
"$TAG"
gh release upload --clobber "$TAG" $ARTIFACTS
env:
GH_TOKEN: ${{ github.token }}
PACKAGE: ${{ env.package }}
TAG: ${{ env.dist_tag }}
NOTES: This is a continuously-updated prerelease generated from `main` (currently at ${{ steps.timestamp_and_hash.outputs.SHORT_HASH }}).
ARTIFACTS: >
schemas/data.schema.json
${{ env.package_dir }}/data.json
data.extended.json