X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=.github%2Fworkflows%2Fci.yml;h=58a8fe5e78ffaaf7c96f4a796e0c615719080299;hb=96678ea574f46d1ea42e7631256d31e8a5259634;hp=30b45b14f2953688fe490262c8a754b5d43387e8;hpb=6ddc8fc5fa990a91503f816001d216a002a3ddae;p=poolifier.git diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 30b45b14..58a8fe5e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -7,20 +7,21 @@ on: 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'] + node: ['18.x', '20.x', '21.x'] + + name: Node.js ${{ matrix.node }} on ${{ matrix.os }} + + runs-on: ${{ matrix.os }} steps: - name: Checkout @@ -34,35 +35,46 @@ jobs: version: 8 - name: Setup Node.js ${{ matrix.node }} - uses: actions/setup-node@v3 + uses: actions/setup-node@v4 with: node-version: ${{ matrix.node }} cache: 'pnpm' - - name: Install - run: pnpm install + - name: Install Dependencies + run: pnpm install --ignore-scripts --frozen-lockfile - name: Build run: pnpm build - name: Lint - if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }} + if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }} run: pnpm lint - name: Tests 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 == '20.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: Fix Coverage Report Paths + # if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }} + # working-directory: ./coverage + # run: sed -i 's@'$GITHUB_WORKSPACE'@/github/workspace/@g' lcov.info + + - 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 == '20.x' }} + uses: sonarsource/sonarcloud-github-action@v2.1.1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} - - - name: Benchmark - if: github.event.inputs.withBenchmark - run: pnpm benchmark