X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=.github%2Fworkflows%2Fci.yml;h=5b240db0c190eeab896cef6273c3066303f00677;hb=e905ea64c054a25ef73885e41fc063279bc599ca;hp=ac9250510d785378b280816e95d4dc1f5b46c506;hpb=726457b4fe5be9c1f7a05b7463faee55c1a8e96a;p=poolifier.git diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index ac925051..5b240db0 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -7,58 +7,69 @@ 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', '19.x'] + 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@v3 + 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: Setup node ${{ matrix.node }} + - name: Setup pnpm + uses: pnpm/action-setup@v2 + with: + version: 8 + + - name: Setup Node.js ${{ matrix.node }} uses: actions/setup-node@v3 with: node-version: ${{ matrix.node }} + cache: 'pnpm' - name: Install - run: | - corepack enable - corepack prepare pnpm@latest --activate - pnpm install + run: pnpm install --ignore-scripts - name: Build - run: pnpm run build + run: pnpm build - name: Lint - run: pnpm run lint + if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }} + run: pnpm lint - name: Tests - run: pnpm run test + run: pnpm test - name: Coverage Report - if: "github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '18.x'" - run: pnpm run coverage + 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@master + - 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 }} # 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: pnpm run benchmark