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 }}
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
- with:
- version: 8
+ uses: pnpm/action-setup@v4
- 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: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '18.x' }}
+ if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }}
run: pnpm coverage
- name: Check for SonarCloud Token Availability
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.1
+ 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 }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}