Skip to content

build-deploy

build-deploy #4

name: build-deploy
on:
push:
branches:
- main
workflow_dispatch:
inputs:
release_type:
description: "Type of release"
required: true
default: "patch"
type: choice
options:
- patch
- minor
- major
- bugfix
- hotfix
permissions:
contents: write
packages: write
jobs:
test_and_build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: "16"
- name: Clean install dependencies
run: |
rm -rf node_modules
rm -rf package-lock.json
npm i
- name: Build package
run: npm run build
- name: Upload build artifacts
uses: actions/upload-artifact@v3
with:
name: build-artifacts
path: |
lib/
src/
publish:
needs: test_and_build
runs-on: ubuntu-latest
if: github.event_name == 'workflow_dispatch' || github.event_name == 'push'
steps:
- uses: actions/checkout@v3
with:
persist-credentials: false # Disable automatic token authentication
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: "16"
registry-url: "https://registry.npmjs.org"
- name: Download build artifacts
uses: actions/download-artifact@v3
with:
name: build-artifacts
path: ./
- name: Install dependencies
run: npm ci
- name: Configure Git
run: |
git config user.name "${{ github.actor }}"
git config user.email "${{ github.actor }}@users.noreply.github.com"
git remote set-url origin "https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git"
- name: Version and publish
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
run: |
if [[ "${{ github.event_name }}" == "workflow_dispatch" ]]; then
npm version ${{ github.event.inputs.release_type }} -m "Bump version to %s [skip ci]"
else
npm version patch -m "Bump version to %s [skip ci]"
fi
npm publish
- name: Push changes
run: git push --follow-tags