Release: patch #15
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
name: Release | |
run-name: | | |
${{ (github.event_name == 'workflow_dispatch' && inputs.dryrun | |
&& 'Dry run') | |
|| (github.event_name == 'workflow_dispatch' | |
&& format('Release: {0}', (inputs.version == 'custom' && inputs.custom) || inputs.version)) | |
|| format('Release: {0}', github.event.head_commit.message) }} | |
on: | |
# Event: A maintainer has pushed a new release tag for publication. | |
push: | |
tags: | |
- v* | |
# Event: A maintainer has used the GitHub Actions UI to initiate | |
# either tagging a new release for publication or doing a | |
# dry run. | |
workflow_dispatch: | |
inputs: | |
dryrun: | |
description: 'Dry run (no npm publish)' | |
required: false | |
type: boolean | |
default: true | |
version: | |
description: 'Version component to update (or "custom" to provide exact version)' | |
required: true | |
default: 'patch' | |
type: choice | |
options: | |
- patch | |
- minor | |
- major | |
- prepatch | |
- preminor | |
- premajor | |
- prerelease | |
- custom | |
custom: | |
description: 'Custom version' | |
required: false | |
default: '' | |
jobs: | |
setup: | |
name: Setup | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write | |
outputs: | |
dryrun: ${{ steps.dryrun.outputs.dryrun }} | |
publish: ${{ steps.publish.outputs.publish }} | |
ref: ${{ steps.tag.outputs.tag || github.event.repository.default_branch }} | |
tag: ${{ steps.tag.outputs.tag || steps.get-tag.outputs.tag || '' }} | |
steps: | |
- name: Validate Workflow Inputs | |
if: ${{ inputs.version == 'custom' && inputs.custom == '' }} | |
shell: bash | |
run: | | |
echo '::error::No custom version number provided' | |
exit 1 | |
- id: dryrun | |
name: Validate Dry Run Event | |
if: ${{ github.event_name == 'workflow_dispatch' && inputs.dryrun }} | |
shell: bash | |
run: echo dryrun=true >> "$GITHUB_OUTPUT" | |
- id: publish | |
name: Validate Publish Event | |
if: ${{ github.event_name == 'push' || !inputs.dryrun }} | |
shell: bash | |
env: | |
NPM_TOKEN: ${{ secrets.NPM_TOKEN }} | |
run: | | |
if [[ -z $NPM_TOKEN ]]; then | |
echo "::error::Secret NPM_TOKEN is not defined for this GitHub repo." | |
echo "::error::To publish to npm, this action requires:" | |
echo "::error:: • an npm access token;" | |
echo "::error:: • with Read-Write access to this project's npm packages;" | |
echo "::error:: • stored as a repo secret named NPM_TOKEN." | |
echo "::error::See https://docs.npmjs.com/about-access-tokens for info about creating npm tokens." | |
echo "::error::See https://docs.github.com/en/actions/security-guides/using-secrets-in-github-actions for info about how to store GitHub repo secrets." | |
exit 1 | |
fi | |
echo publish=true >> "$GITHUB_OUTPUT" | |
- name: Checkout Code | |
uses: actions/checkout@v3 | |
- name: Set Environment Variables | |
uses: falti/dotenv-action@v1 | |
with: | |
path: ./.github/workflows/.env | |
export-variables: true | |
keys-case: bypass | |
- name: Install Node | |
uses: actions/setup-node@v3 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
registry-url: ${{ env.NPM_REGISTRY }} | |
cache: npm | |
- name: Install Dependencies | |
shell: bash | |
run: npm ci | |
- name: Tag Release (manual only) | |
if: ${{ github.event_name == 'workflow_dispatch' && !inputs.dryrun }} | |
id: tag | |
shell: bash | |
run: | | |
git config --global user.name $ACTIONS_USER | |
git config --global user.email $ACTIONS_EMAIL | |
npm run release -- '${{ (inputs.version == 'custom' && inputs.custom) || inputs.version }}' | |
echo tag=$(git describe --abbrev=0) >> "$GITHUB_OUTPUT" | |
- name: Get Tag (push only) | |
if: ${{ github.event_name == 'push' }} | |
id: get-tag | |
uses: olegtarasov/[email protected] | |
- name: Diagnostics | |
if: ${{ github.event_name == 'workflow_dispatch' && !inputs.dryrun }} | |
shell: bash | |
run: git tag --sort=-taggerdate | |
build: | |
name: Build | |
needs: [setup] | |
permissions: | |
contents: write | |
uses: ./.github/workflows/build.yml | |
with: | |
ref: ${{ needs.setup.outputs.ref }} | |
tag: ${{ needs.setup.outputs.tag }} | |
update-version: ${{ !!needs.setup.outputs.dryrun }} | |
version: ${{ (inputs.version == 'custom' && inputs.custom) || inputs.version }} | |
github-release: ${{ !!needs.setup.outputs.publish }} | |
publish: | |
name: Publish | |
if: ${{ needs.setup.outputs.publish }} | |
needs: [setup, build] | |
runs-on: ubuntu-latest | |
permissions: | |
contents: write | |
steps: | |
- name: Checkout Code | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Diagnostics | |
shell: bash | |
run: git tag --sort=-taggerdate | |
- name: Set Environment Variables | |
uses: falti/dotenv-action@v1 | |
with: | |
path: ./.github/workflows/.env | |
export-variables: true | |
keys-case: bypass | |
- name: Diagnostics | |
shell: bash | |
run: | | |
echo 'needs.setup.outputs.tag=${{ needs.setup.outputs.tag }}' | |
git log -10 | |
- name: Install Node | |
uses: actions/setup-node@v3 | |
with: | |
node-version: ${{ env.NODE_VERSION }} | |
registry-url: ${{ env.NPM_REGISTRY }} | |
cache: npm | |
- name: Install Dependencies | |
shell: bash | |
run: npm ci | |
- name: Fetch (cargo-messages) | |
uses: robinraju/[email protected] | |
with: | |
tag: ${{ needs.setup.outputs.tag }} | |
fileName: "*.tgz" | |
out-file-path: ./pkgs/cargo-messages/dist | |
- name: Diagnostics | |
shell: bash | |
run: ls -al | |
working-directory: ./pkgs/cargo-messages/dist | |
- name: Publish (cargo-messages) | |
shell: bash | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
run: | | |
for p in *.tgz ; do | |
echo "UNPACKING: $p" | |
ls -al ./$p | |
mkdir -p tmp-unpack | |
cd tmp-unpack | |
cp ../$p ./ | |
tar xzf $p | |
ls -al ./package | |
cat ./package/package.json | |
cd .. | |
rm -rf tmp-unpack | |
mv $p /tmp | |
pushd /tmp | |
npm publish --access public ./$p | |
popd | |
echo "NEEEEEXT" | |
done | |
working-directory: ./pkgs/cargo-messages/dist | |
- name: Build (@neon-rs/load) | |
shell: bash | |
run: npm run build | |
working-directory: ./pkgs/load | |
- name: Publish (@neon-rs/load) | |
shell: bash | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
run: npm publish --access public | |
working-directory: ./pkgs/load | |
- name: Publish (@neon-rs/cli) | |
shell: bash | |
env: | |
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | |
run: npm publish --access public | |
working-directory: ./dist/cli |