From 9dac7cf72fa288f621be69643e521b8b146b12d6 Mon Sep 17 00:00:00 2001 From: Tom Whittington Date: Fri, 16 Aug 2024 13:13:22 +0100 Subject: [PATCH 1/5] Added basic sonar check --- .github/workflows/code-pr-check.yml | 66 ++++++++++++++++++++++++----- 1 file changed, 55 insertions(+), 11 deletions(-) diff --git a/.github/workflows/code-pr-check.yml b/.github/workflows/code-pr-check.yml index 655db94..fe172b9 100644 --- a/.github/workflows/code-pr-check.yml +++ b/.github/workflows/code-pr-check.yml @@ -30,16 +30,60 @@ jobs: - name: Setup .NET uses: actions/setup-dotnet@v4 with: - dotnet-version: 8.0.x - - - name: Restore dependencies - run: dotnet restore - - - name: Build - run: dotnet build --no-restore - - - name: Test - run: dotnet test --no-build --verbosity normal - + dotnet-version: ${{ env.DOTNET_VERSION }} + cache: false + - name: Install dotnet coverage run: dotnet tool install --global dotnet-coverage --version 17.9.3 + + - name: Cache SonarCloud packages + uses: actions/cache@v4 + with: + path: ~\sonar\cache + key: ${{ runner.os }}-sonar + restore-keys: ${{ runner.os }}-sonar + + - name: Install SonarCloud scanners + run: dotnet tool install --global dotnet-sonarscanner + + - name: Install latest JDK + uses: actions/setup-java@v4 + with: + distribution: "microsoft" + java-version: "17" + + - name: Start SonarCloud scanner + run: | + dotnet-sonarscanner begin \ + /k:"DFE-Digital_sts-content-support" \ + /o:"dfe-digital" \ + /d:sonar.login="${{ secrets.SONAR_TOKEN }}" \ + /d:sonar.host.url="https://sonarcloud.io" \ + /d:sonar.cs.vscoveragexml.reportsPaths=coverage.xml \ + /d:sonar.coverage.exclusions=**/Program.cs,**/wwwroot/** \ + /d:sonar.issue.ignore.multicriteria=e1 \ + /d:sonar.issue.ignore.multicriteria.e1.ruleKey=csharpsquid:S6602 \ + /d:sonar.issue.ignore.multicriteria.e1.resourceKey=src/**/*.cs + + - name: Build web app + uses: ././actions/build-dotnet-app + with: + dotnet_version: ${{ env.DOTNET_VERSION }} + solution_filename: sts-contentsupport.sln + + - name: Run unit tests + uses: ././actions/run-unit-tests + with: + solution_filename: sts-contentsupport.sln + + - name: Merge test results + run: dotnet-coverage merge -f xml -o "coverage.xml" -s "coverage.settings.xml" -r coverage.cobertura.xml + + - name: End SonarCloud Scanner + run: dotnet-sonarscanner end /d:sonar.login="${{ secrets.SONAR_TOKEN }}" + + - name: Archive code coverage results + uses: actions/upload-artifact@v4 + with: + name: code-coverage-report + path: coverage.xml From 2e94bbcbc58e084e6887af94c5cd6f5c0852aeac Mon Sep 17 00:00:00 2001 From: Tom Whittington Date: Fri, 16 Aug 2024 13:26:09 +0100 Subject: [PATCH 2/5] Build and test enabled --- .github/workflows/code-pr-check.yml | 51 +++++++++++++++-------------- 1 file changed, 26 insertions(+), 25 deletions(-) diff --git a/.github/workflows/code-pr-check.yml b/.github/workflows/code-pr-check.yml index fe172b9..6430dd0 100644 --- a/.github/workflows/code-pr-check.yml +++ b/.github/workflows/code-pr-check.yml @@ -52,38 +52,39 @@ jobs: distribution: "microsoft" java-version: "17" - - name: Start SonarCloud scanner - run: | - dotnet-sonarscanner begin \ - /k:"DFE-Digital_sts-content-support" \ - /o:"dfe-digital" \ - /d:sonar.login="${{ secrets.SONAR_TOKEN }}" \ - /d:sonar.host.url="https://sonarcloud.io" \ - /d:sonar.cs.vscoveragexml.reportsPaths=coverage.xml \ - /d:sonar.coverage.exclusions=**/Program.cs,**/wwwroot/** \ - /d:sonar.issue.ignore.multicriteria=e1 \ - /d:sonar.issue.ignore.multicriteria.e1.ruleKey=csharpsquid:S6602 \ - /d:sonar.issue.ignore.multicriteria.e1.resourceKey=src/**/*.cs +# - name: Start SonarCloud scanner +# run: | +# dotnet-sonarscanner begin \ +# /k:"DFE-Digital_sts-content-support" \ +# /o:"dfe-digital" \ +# /d:sonar.login="${{ secrets.SONAR_TOKEN }}" \ +# /d:sonar.host.url="https://sonarcloud.io" \ +# /d:sonar.cs.vscoveragexml.reportsPaths=coverage.xml \ +# /d:sonar.coverage.exclusions=**/Program.cs,**/wwwroot/** \ +# /d:sonar.issue.ignore.multicriteria=e1 \ +# /d:sonar.issue.ignore.multicriteria.e1.ruleKey=csharpsquid:S6602 \ +# /d:sonar.issue.ignore.multicriteria.e1.resourceKey=src/**/*.cs - name: Build web app - uses: ././actions/build-dotnet-app + uses: ./.github/actions/build-dotnet-app with: dotnet_version: ${{ env.DOTNET_VERSION }} solution_filename: sts-contentsupport.sln - name: Run unit tests - uses: ././actions/run-unit-tests + uses: ./.github/actions/run-unit-tests with: solution_filename: sts-contentsupport.sln - - name: Merge test results - run: dotnet-coverage merge -f xml -o "coverage.xml" -s "coverage.settings.xml" -r coverage.cobertura.xml - - - name: End SonarCloud Scanner - run: dotnet-sonarscanner end /d:sonar.login="${{ secrets.SONAR_TOKEN }}" - - - name: Archive code coverage results - uses: actions/upload-artifact@v4 - with: - name: code-coverage-report - path: coverage.xml +# - name: Merge test results +# run: dotnet-coverage merge -f xml -o "coverage.xml" -s "coverage.settings.xml" -r coverage.cobertura.xml +# +# - name: End SonarCloud Scanner +# run: dotnet-sonarscanner end /d:sonar.login="${{ secrets.SONAR_TOKEN }}" +# +# - name: Archive code coverage results +# uses: actions/upload-artifact@v4 +# with: +# name: code-coverage-report +# path: coverage.xml +# \ No newline at end of file From c545eb94d2b1431ee6c0be99fe78886812b0044a Mon Sep 17 00:00:00 2001 From: Tom Whittington Date: Fri, 16 Aug 2024 13:30:10 +0100 Subject: [PATCH 3/5] Removed manual trigger on deploy --- .github/workflows/matrix-deploy.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/matrix-deploy.yml b/.github/workflows/matrix-deploy.yml index b567062..d80c84e 100644 --- a/.github/workflows/matrix-deploy.yml +++ b/.github/workflows/matrix-deploy.yml @@ -1,7 +1,6 @@ name: Multi stage build & deploy on: - workflow_dispatch: push: branches: ["main", "development"] paths: From d84d80b3928ecc9ecb831eeb75d7ea9e20b7970a Mon Sep 17 00:00:00 2001 From: Tom Whittington Date: Fri, 16 Aug 2024 13:30:57 +0100 Subject: [PATCH 4/5] Removed push builds --- .github/workflows/code-pr-check.yml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/.github/workflows/code-pr-check.yml b/.github/workflows/code-pr-check.yml index 6430dd0..0c43a2b 100644 --- a/.github/workflows/code-pr-check.yml +++ b/.github/workflows/code-pr-check.yml @@ -1,11 +1,6 @@ name: Code PR Check on: - push: - branches: ["main", "Development"] - paths: - - "src/**" - - "tests/**" pull_request: branches: ["main", "Development"] paths: From 240e3e6139686ec7a46e3ebd947ba19f86588bbc Mon Sep 17 00:00:00 2001 From: Tom Whittington Date: Fri, 16 Aug 2024 13:35:22 +0100 Subject: [PATCH 5/5] Fixed branch name --- .github/workflows/matrix-deploy.yml | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/.github/workflows/matrix-deploy.yml b/.github/workflows/matrix-deploy.yml index d80c84e..ed258f9 100644 --- a/.github/workflows/matrix-deploy.yml +++ b/.github/workflows/matrix-deploy.yml @@ -1,8 +1,9 @@ name: Multi stage build & deploy on: + workflow_dispatch: push: - branches: ["main", "development"] + branches: [ "main", "Development" ] paths: - "src/**" - ".github/workflows/matrix-deploy.yml" @@ -36,20 +37,20 @@ jobs: checked-out-sha: ${{ needs.set-env.outputs.checked-out-sha }} create-and-tag-release: - needs: [set-env, create-and-publish-image] + needs: [ set-env, create-and-publish-image ] name: Create & Tag Release uses: ./.github/workflows/create-tag-release.yml secrets: inherit deploy-to-dev: - needs: [set-env, create-and-publish-image] + needs: [ set-env, create-and-publish-image ] name: Deployment to Dev & Test strategy: max-parallel: 1 fail-fast: true matrix: - target: [Dev] + target: [ Dev ] uses: ./.github/workflows/deploy-image.yml with: environment: ${{ matrix.target }}