Skip to content

Release

Release #8

Workflow file for this run

name: Release
on: [workflow_call, workflow_dispatch]
env:
NODE_VERSION: 20
CI: true
jobs:
release:
name: Release
runs-on: ubuntu-22.04
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: actions-ecosystem/action-get-latest-tag@v1
id: version
# - name: Validate version from git tag
# if: steps.version.outputs.is_valid != 'true'
# run: echo "Tag must follow SemVer convention. Aborting." && exit 1
- name: Set up Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}
- name: Assign dist tag
id: dist-tag
uses: actions/github-script@v7
with:
result-encoding: string
script: |
const gitTag = '${{ steps.version.outputs.tag }}'
console.log(`git tag: ${gitTag}`)
if (gitTag.match(/^v\d+\.\d+\.\d+$/)) {
distTag = 'latest'
} else if (gitTag.match(/^v\d+\.\d+\.\d+/)) {
distTag = 'alpha'
} else {
core.setFailed('Tag must follow SemVer convention. Aborting.');
}
console.log(`npm dist tag: ${distTag}`)
return distTag
- name: Install
run: |
corepack enable
yarn install
- name: Build
run: |
yarn lint
yarn build
yarn test
- name: Configure yarn to publish packages
env:
NPM_AUTH_TOKEN: ${{ secrets.NPM_CARTODB_AUTH_TOKEN }}
run: |
yarn config set npmPublishRegistry "https://registry.npmjs.org/"
yarn config set npmAuthToken "${NPM_AUTH_TOKEN}"
- name: Publish
env:
DIST_TAG: ${{ steps.dist-tag.outputs.result }}
run: yarn npm publish --tag ${DIST_TAG}