Skip to content

Manual Pre-Release Publish #103

Manual Pre-Release Publish

Manual Pre-Release Publish #103

Workflow file for this run

---
name: Manual Pre-Release Publish
on:
workflow_dispatch:
inputs:
branch:
description: 'Branch. Defaults to "main".'
required: true
default: 'main'
npmTag:
description: 'NPM tag. Defaults to "next".'
required: true
default: 'next'
preReleaseName:
description: 'Pre-release name. This is used in the version string, e.g. "beta" for `7.0.0-beta.0`. Defaults to "next".'
required: true
default: 'next'
preReleaseVersion:
description: 'The new pre-release version to create. Choose "existing" to increment the latest pre-release.'
required: true
type: choice
options:
- existing
- patch
- minor
- major
dryRun:
description: 'Do not touch or write anything. Show the commands.'
required: true
default: false
type: boolean
env:
DRY_RUN_ARG: ${{ inputs.dryRun && '--dry-run' || '' }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
HUSKY: '0'
jobs:
release:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
ref: ${{inputs.branch}}
fetch-depth: 0
- uses: actions/setup-node@v4
with:
node-version: 20.x
- uses: pnpm/action-setup@v4
with:
run_install: false
- name: Package Manager Setup
run: |
pnpm set registry "https://registry.npmjs.org/"
pnpm set //registry.npmjs.org/:_authToken $NPM_TOKEN
pnpm whoami
- name: Git Setup
run: |
git config --global user.email "bot@webdriver.io"
git config --global user.name "WebdriverIO Release Bot"
- name: Pushing to the protected branch 'main'
uses: CasperWA/push-protected@v2
with:
token: ${{ secrets.DEPLOY_PAT }}
branch: main
- name: Install Dependencies
run: pnpm install --frozen-lockfile
- name: Publish Pre-Release
run: |
pnpm run build
if [ "${{inputs.preReleaseVersion}}" == "existing" ]; then
pnpx tsx scripts/release.ts $DRY_RUN_ARG --preRelease=${{inputs.preReleaseName}} --npm.tag=${{inputs.npmTag}} --no-git.requireupstream
else
pnpx tsx scripts/release.ts ${{inputs.preReleaseVersion}} $DRY_RUN_ARG --preRelease=${{inputs.preReleaseName}} --npm.tag=${{inputs.npmTag}} --no-git.requireupstream
fi
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}