Use a supported GH action to read package.json
[poolifier.git] / .github / workflows / ci.yml
index f70f2238d55b9e4e54444e5c8f8459fa231ca7d8..80e716564d76e050e788de5454bbdf4c4dce6929 100644 (file)
@@ -2,9 +2,8 @@ name: CI
 
 on:
   push:
-    branches:
-      - master
-  pull_request_target:
+    branches: [master]
+  pull_request:
     types: [opened, synchronize, reopened]
   workflow_dispatch:
     inputs:
@@ -14,22 +13,23 @@ on:
 
 jobs:
   build:
-    runs-on: ubuntu-latest
+    runs-on: ${{ matrix.os }}
 
     strategy:
       matrix:
-        node-version: [12.x, 14.x, 16.x]
+        os: [windows-latest, macos-latest, ubuntu-latest]
+        node: ['16.x', '18.x', '19.x']
 
     steps:
       - name: Checkout
-        uses: actions/checkout@v2
+        uses: actions/checkout@v3
         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-version }}
-        uses: actions/setup-node@v2
+      - name: Setup node ${{ matrix.node }}
+        uses: actions/setup-node@v3
         with:
-          node-version: ${{ matrix.node-version }}
+          node-version: ${{ matrix.node }}
 
       - name: Install
         run: npm ci
@@ -40,16 +40,16 @@ jobs:
       - name: Lint
         run: npm run lint
 
-      - name: Tests & Coverage
-        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-version == '14.x'"
-        uses: SonarSource/sonarcloud-github-action@master
+        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
           SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}