on:
push:
- branches:
- - master
- pull_request_target:
+ branches: [master]
+ pull_request:
types: [opened, synchronize, reopened]
- branches:
- - master
- workflow_dispatch:
- inputs:
- withBenchmark:
- description: 'With Benchmark?'
- default: false
+ merge_group:
+ branches: [master]
+
+permissions:
+ contents: read
+ checks: read
jobs:
build:
- runs-on: ubuntu-latest
-
strategy:
matrix:
- node-version: [12.x, 14.x, 16.x]
+ os: [windows-latest, macos-latest, ubuntu-latest]
+ node: ['18.x', '20.x', 'latest']
+
+ name: Node.js ${{ matrix.node }} on ${{ matrix.os }}
+
+ runs-on: ${{ matrix.os }}
steps:
- name: Checkout
- uses: actions/checkout@v2
+ uses: actions/checkout@v4
with:
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis. This is needed for better sonar
- - name: Set node version to ${{ matrix.node-version }}
- uses: actions/setup-node@v2
+ - name: Setup pnpm
+ uses: pnpm/action-setup@v4
+
+ - name: Setup Node.js ${{ matrix.node }}
+ uses: actions/setup-node@v4
with:
- node-version: ${{ matrix.node-version }}
+ node-version: ${{ matrix.node }}
+ cache: 'pnpm'
- - name: Install
- run: npm ci
+ - name: Install Dependencies
+ run: pnpm install --ignore-scripts --frozen-lockfile
- name: Build
- run: npm run build --if-present
+ run: pnpm build
- name: Lint
- run: npm run lint
+ if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }}
+ run: pnpm lint
- - name: Tests & Coverage
+ - name: Tests
+ run: pnpm test
+
+ - name: Coverage Report
+ if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }}
+ run: pnpm coverage
+
+ - name: Check for SonarCloud Token Availability
+ id: sonar-token
+ shell: bash
run: |
- npm run test
- npm run coverage
- env:
- CI: true
+ if [ "${{ secrets.SONAR_TOKEN }}" != '' ]; then
+ echo "available=true" >> $GITHUB_OUTPUT;
+ else
+ echo "available=false" >> $GITHUB_OUTPUT;
+ fi
- - name: Sonar Code Analysis
- if: "github.repository == 'poolifier/poolifier' && matrix.node-version == '14.x'"
- uses: SonarSource/sonarcloud-github-action@master
+ - name: SonarCloud Code Analysis
+ if: ${{ steps.sonar-token.outputs.available == 'true' && github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }}
+ uses: sonarsource/sonarcloud-github-action@v2.3.0
env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
-
- - name: Benchmark
- if: github.event.inputs.withBenchmark
- run: npm run benchmark