repositories
/
poolifier.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
chore: v3.0.6
[poolifier.git]
/
.github
/
workflows
/
ci.yml
diff --git
a/.github/workflows/ci.yml
b/.github/workflows/ci.yml
index f4b4e42299393e20c75e04b974024233391a3c8b..301adb02afce62b0e2265a67c9966cce0a301504 100644
(file)
--- a/
.github/workflows/ci.yml
+++ b/
.github/workflows/ci.yml
@@
-2,61
+2,74
@@
name: CI
on:
push:
on:
push:
- branches:
- - master
+ branches: [master]
pull_request:
types: [opened, synchronize, reopened]
pull_request:
types: [opened, synchronize, reopened]
- workflow_dispatch:
- inputs:
- withBenchmark:
- description: 'With Benchmark?'
- default: false
+ merge_group:
+ branches: [master]
+
+permissions:
+ contents: read
+ checks: read
jobs:
build:
jobs:
build:
- runs-on: ${{ matrix.os }}
-
strategy:
matrix:
os: [windows-latest, macos-latest, ubuntu-latest]
strategy:
matrix:
os: [windows-latest, macos-latest, ubuntu-latest]
- node: ['16.x', '18.x']
+ node: ['18.x', '20.x', '21.x']
+
+ name: Node.js ${{ matrix.node }} on ${{ matrix.os }}
+
+ runs-on: ${{ matrix.os }}
steps:
- name: Checkout
steps:
- name: Checkout
- uses: actions/checkout@v
3
+ uses: actions/checkout@v
4
with:
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis. This is needed for better sonar
with:
fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis. This is needed for better sonar
- - name: Set node version to ${{ matrix.node }}
- uses: actions/setup-node@v3
+ - name: Setup pnpm
+ uses: pnpm/action-setup@v2
+ with:
+ version: 8
+
+ - name: Setup Node.js ${{ matrix.node }}
+ uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
with:
node-version: ${{ matrix.node }}
+ cache: 'pnpm'
- - name: Install
- run:
npm ci
+ - name: Install
Dependencies
+ run:
pnpm install --ignore-scripts --frozen-lockfile
- name: Build
- name: Build
- run:
npm run build --if-present
+ run:
pnpm build
- name: Lint
- name: Lint
- run: npm run lint
+ if: ${{ matrix.os == 'ubuntu-latest' && matrix.node == '20.x' }}
+ run: pnpm lint
- name: Tests
- name: Tests
- run:
npm run
test
+ run:
pnpm
test
- - name: Coverage & Linter Reports
- if: "github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '16.x'"
+ - 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: |
run: |
- npm run coverage
- npm run lint:report
+ if [ "${{ secrets.SONAR_TOKEN }}" != '' ]; then
+ echo "available=true" >> $GITHUB_OUTPUT;
+ else
+ echo "available=false" >> $GITHUB_OUTPUT;
+ fi
- - name: Sonar Code Analysis
- if:
"github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '16.x'"
- uses: sonarsource/sonarcloud-github-action@
master
+ - name: Sonar
Cloud
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.0.2
env:
env:
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# Needed to get PR information, if any
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
-
- - name: Benchmark
- if: github.event.inputs.withBenchmark
- run: npm run benchmark