types: [opened, synchronize, reopened]
merge_group:
branches: [master]
- workflow_dispatch:
- inputs:
- withBenchmark:
- description: 'With Benchmark?'
- default: false
+
+permissions:
+ contents: read
+ checks: read
jobs:
build:
- runs-on: ${{ matrix.os }}
-
strategy:
matrix:
os: [windows-latest, macos-latest, ubuntu-latest]
node: ['16.x', '18.x', '20.x']
+ name: Node.js ${{ matrix.node }} on ${{ matrix.os }}
+
+ runs-on: ${{ matrix.os }}
+
steps:
- name: Checkout
uses: actions/checkout@v4
node-version: ${{ matrix.node }}
cache: 'pnpm'
- - name: Install
- run: pnpm install
+ - name: Install Dependencies
+ run: pnpm install --ignore-scripts
- name: Build
run: pnpm build
run: pnpm test
- name: Coverage Report
- if: ${{ github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }}
+ if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }}
run: pnpm coverage
- - name: Sonar Code Analysis
- if: ${{ github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }}
- uses: sonarsource/sonarcloud-github-action@v2.0.0
+ - name: Check for SonarCloud Token Availability
+ id: sonar-token
+ shell: bash
+ run: |
+ if [ "${{ secrets.SONAR_TOKEN }}" != '' ]; then
+ echo "available=true" >> $GITHUB_OUTPUT;
+ else
+ echo "available=false" >> $GITHUB_OUTPUT;
+ fi
+
+ - name: SonarCloud Code Analysis
+ if: ${{ steps.sonar-token.outputs.available == 'true' && github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }}
+ uses: sonarsource/sonarcloud-github-action@v2.0.2
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
-
- - name: Benchmark
- if: github.event.inputs.withBenchmark
- run: pnpm benchmark