Skip to content

build(deps): update dependency @types/node to v20.11.29 (#23) #74

build(deps): update dependency @types/node to v20.11.29 (#23)

build(deps): update dependency @types/node to v20.11.29 (#23) #74

name: Release
on: [push, workflow_dispatch]
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
test:
runs-on: ubuntu-latest
steps:
- name: Checkout 🧳
uses: actions/checkout@v4
- name: Install Node.js 🔥
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install pnpm 👀
uses: pnpm/action-setup@v3
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory 🏪
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- name: Setup pnpm cache 💰
uses: actions/cache@v4
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies ⏬
run: pnpm install --no-frozen-lockfile
- name: Build ⏰
run: pnpm run build
env:
NODE_ENV: production
- name: Test 🔫
run: pnpm run test:coverage
- name: Report Coverage 📝
if: always() # Also generate the report if tests are failing
uses: davelosert/vitest-coverage-report-action@v2
# - name: Get Coverage for badge 🔢
# run: |
# COVERAGE="$(cat coverage/coverage-summary.json | jq -r '.total.lines.pct')"
# echo "COVERAGE=$(echo ${COVERAGE})" >> $GITHUB_ENV
# - name: Create coverage badge ✍🏽
# uses: schneegans/dynamic-badges-action@v1.6.0
# with:
# auth: ${{ secrets.GIST_SECRET }}
# gistID: 275fdb9d0c3b23cafa916535c807ce6a
# filename: ts-npm-template-coverage.json
# label: Code Coverage
# message: ${{ env.COVERAGE }}
# color: green
# namedLogo: vitest
- name: Upload Test Results ⏫
uses: actions/upload-artifact@v4
with:
name: coverage
path: coverage/
release:
# Release only when code is pushed to main branch
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }}
runs-on: ubuntu-latest
permissions:
contents: write # to be able to publish a GitHub release
issues: write # to be able to comment on released issues
pull-requests: write # to be able to comment on released pull requests
id-token: write # to enable use of OIDC for npm provenance
needs: [test]
steps:
- name: Checkout 🧳
uses: actions/checkout@v4
- name: Install Node.js 🔥
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install pnpm 👀
uses: pnpm/action-setup@v3
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory 🏪
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- name: Setup pnpm cache 💰
uses: actions/cache@v4
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies ⏬
run: pnpm install --no-frozen-lockfile
- name: Build ⏰
run: pnpm build
env:
NODE_ENV: production
- name: Release 🚀
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
run: pnpm semantic-release