X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=.github%2Fworkflows%2Fci.yml;h=afcfc1f126185417eaa384c86a7a294fa30be359;hb=3d5424d527d95ae9141ac916b121510762f8b7f3;hp=718e7ac70127f4c0dc3a2406285dc461fae7716a;hpb=f725dbf0368c00546e08e5b884ded0d93e8563e0;p=poolifier.git diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 718e7ac7..afcfc1f1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -7,18 +7,17 @@ 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: strategy: matrix: os: [windows-latest, macos-latest, ubuntu-latest] - node: ['16.x', '18.x', '20.x'] + node: ['18.x', '20.x', 'latest'] name: Node.js ${{ matrix.node }} on ${{ matrix.os }} @@ -31,40 +30,46 @@ jobs: fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis. This is needed for better sonar - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: - version: 8 + version: 9 - 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 --ignore-scripts + - 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.1 + - 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