name: CI on: push: branches: [master] pull_request: types: [opened, synchronize, reopened] merge_group: branches: [master] permissions: contents: read checks: read jobs: build: strategy: matrix: 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@v4 with: 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@v3 with: version: 9 - name: Setup Node.js ${{ matrix.node }} uses: actions/setup-node@v4 with: node-version: ${{ matrix.node }} cache: 'pnpm' - name: Install Dependencies run: pnpm install --ignore-scripts --frozen-lockfile - name: Build run: pnpm build - name: Lint if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }} run: pnpm lint - 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: | 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 }}