Use a supported GH action to read package.json
[poolifier.git] / .github / workflows / ci.yml
index 044210ac2330587481f5bfd3132bbe9e2d8a1a75..80e716564d76e050e788de5454bbdf4c4dce6929 100644 (file)
@@ -2,8 +2,7 @@ name: CI
 
 on:
   push:
-    branches:
-      - master
+    branches: [master]
   pull_request:
     types: [opened, synchronize, reopened]
   workflow_dispatch:
@@ -14,11 +13,12 @@ on:
 
 jobs:
   build:
-    runs-on: ubuntu-latest
+    runs-on: ${{ matrix.os }}
 
     strategy:
       matrix:
-        node: ['12.x', '14.x', '16.x']
+        os: [windows-latest, macos-latest, ubuntu-latest]
+        node: ['16.x', '18.x', '19.x']
 
     steps:
       - name: Checkout
@@ -26,7 +26,7 @@ jobs:
         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 }}
+      - name: Setup node ${{ matrix.node }}
         uses: actions/setup-node@v3
         with:
           node-version: ${{ matrix.node }}
@@ -40,16 +40,15 @@ jobs:
       - name: Lint
         run: npm run lint
 
-      - name: Tests & Coverage
-        if: matrix.node-version == '16.x'
-        run: |
-          npm run test
-          npm run coverage
-        env:
-          CI: true
+      - name: Tests
+        run: npm run test
+
+      - name: Coverage Report
+        if: "github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '16.x'"
+        run: npm run coverage
 
       - name: Sonar Code Analysis
-        if: "github.repository == 'poolifier/poolifier' && matrix.node == '16.x'"
+        if: "github.repository == 'poolifier/poolifier' && matrix.os == 'ubuntu-latest' && matrix.node == '16.x'"
         uses: sonarsource/sonarcloud-github-action@master
         env:
           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Needed to get PR information, if any