Skip to content

Pipeline

Pipeline #149

Workflow file for this run

name: 'Pipeline'
on:
push:
branches: ['main']
pull_request:
types: [opened, synchronize]
workflow_dispatch:
inputs:
release-type:
description: 'Type of release (major, minor, patch, alpha)'
required: true
default: alpha
type: choice
options:
- major
- minor
- patch
- alpha
package:
description: 'Which package to release'
required: true
default: ssi
type: choice
options:
- ssi
- digilocker
jobs:
continuous-integration:
name: 'Continuous Integration'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: pnpm/action-setup@v3
with:
version: 9.1.0
- name: Install dependencies
run: pnpm install
- name: Check formatting
run: pnpm check-format
- name: Check types
run: pnpm check-types
- name: Test
run: pnpm test
continuous-deployment:
if: github.event_name == 'workflow_dispatch'
name: 'Continuous Deployment'
runs-on: ubuntu-latest
needs: ['continuous-integration']
steps:
- uses: actions/checkout@v4
with:
token: ${{ secrets.GH_TOKEN }}
- uses: pnpm/action-setup@v3
with:
version: 9.1.0
- name: Install dependencies
run: pnpm install
- name: Build
run: pnpm build
- name: Initialise the NPM config
env:
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
run: npm config set //registry.npmjs.org/:_authToken $NPM_TOKEN
- name: Publish
env:
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
shell: bash
run: |
git config --global user.email "[email protected]"
git config --global user.name "Amit Padmani"
if [ ${{ inputs.release-type }} == 'alpha' ]; then
pnpm run --dir packages/${{ inputs.package }} release --preRelease=${{ inputs.release-type }} --npm.tag=alpha
else
pnpm run --dir packages/${{ inputs.package }} release ${{ inputs.release-type }} --npm.tag=latest
fi