Skip to content

feat: upload coverage reports as GitHub Actions artifacts #282

feat: upload coverage reports as GitHub Actions artifacts

feat: upload coverage reports as GitHub Actions artifacts #282

Workflow file for this run

name: Test
on: [push, pull_request]
jobs:
tests:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- uses: pnpm/action-setup@v3
name: Install pnpm
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
- uses: actions/cache@v4
name: Setup pnpm cache
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
- name: Check fomatting
run: pnpm run format-check
- name: Test building
run: pnpm run build && pnpm run clean
- name: Run shared unit tests
run: pnpm --filter shared test:cov
- name: Upload shared unit test coverage report
uses: actions/upload-artifact@v4
with:
name: shared-unit-coverage-report
path: ./shared/coverage/lcov.info
- name: Run api unit tests
run: pnpm --filter api test:cov
- name: Upload api unit test coverage report
uses: actions/upload-artifact@v4
with:
name: api-unit-coverage-report
path: ./coverage/api/lcov.info
- name: Run api e2e tests
env:
DATABASE_TYPE: sqlite
DATABASE_NAME: ":memory:"
DATABASE_SYNCHRONIZE: true
AUTH0_ISSUER_URL: ${{ secrets.TEST_AUTH0_ISSUER_URL }}
AUTH0_AUDIENCE: ${{ secrets.TEST_AUTH0_AUDIENCE }}
AUTH0_CLIENT_ID: ${{ secrets.TEST_AUTH0_CLIENT_ID }}
AUTH0_CLIENT_SECRET: ${{ secrets.TEST_AUTH0_CLIENT_SECRET }}
run: pnpm --filter api test-e2e:cov
- name: Upload api end-to-end test coverage report
uses: actions/upload-artifact@v4
with:
name: api-e2e-coverage-report
path: ./coverage/api-e2e/lcov.info
- name: SonarCloud Scan
uses: SonarSource/sonarcloud-github-action@master
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}