From 1f2e144b86cc9fd42de1b8559e26ea08a6694022 Mon Sep 17 00:00:00 2001 From: Guilherme Branco Stracini Date: Tue, 12 Nov 2024 14:55:31 +0000 Subject: [PATCH] Create sonarcloud.yml (#365) * Create sonarcloud.yml * Update sonarcloud.yml --------- Co-authored-by: gstraccini[bot] <150967461+gstraccini[bot]@users.noreply.github.com> --- .github/workflows/sonarcloud.yml | 61 ++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 .github/workflows/sonarcloud.yml diff --git a/.github/workflows/sonarcloud.yml b/.github/workflows/sonarcloud.yml new file mode 100644 index 000000000..148895a47 --- /dev/null +++ b/.github/workflows/sonarcloud.yml @@ -0,0 +1,61 @@ +name: SonarCloud Analysis + +on: + push: + branches: + - main + pull_request: + types: [opened, synchronize, reopened] + +jobs: + SonarCloudAnalysis: + name: SonarCloud Analysis + runs-on: ubuntu-latest + + steps: + - name: Set up Java + uses: actions/setup-java@v4 + with: + distribution: 'temurin' + java-version: 21 + + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + + - name: Cache SonarCloud packages + uses: actions/cache@v4 + with: + path: ~/.sonar/cache + key: ${{ runner.os }}-sonar + restore-keys: ${{ runner.os }}-sonar + + - name: Cache SonarCloud scanner + id: cache-sonar-scanner + uses: actions/cache@v4 + with: + path: ~/.sonar/cache + key: ${{ runner.os }}-sonar-scanner + restore-keys: ${{ runner.os }}-sonar-scanner + + - name: Install SonarCloud scanner + if: steps.cache-sonar-scanner.outputs.cache-hit != 'true' + run: dotnet tool update dotnet-sonarscanner --tool-path ~/.sonar/cache/ + + - name: Set SonarCloud variables + shell: bash + run: | + KEY="${{ github.repository_owner }}_${{ github.event.repository.name }}" + ORG="${{ github.repository_owner }}" + echo "KEY=${KEY}" >> "${GITHUB_ENV}" # Keep the variable KEY as it + echo "ORG=${ORG@L}" >> "${GITHUB_ENV}" # Lowercase the ORG variable + + - name: Build and analyze + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} + run: | + ~/.sonar/cache/dotnet-sonarscanner begin /k:"${{ env.KEY }}" /o:"${{ env.ORG }}" /d:sonar.token="${{ secrets.SONAR_TOKEN }}" /d:sonar.host.url="https://sonarcloud.io" /d:sonar.scanner.scanAll=false /d:sonar.cs.opencover.reportsPaths="Tests/**/coverage.net8.0.opencover.xml" + dotnet build -c Release --verbosity minimal + dotnet test -c Release --verbosity minimal --no-build --no-restore /p:CollectCoverage=true /p:CoverletOutputFormat="opencover" + ~/.sonar/cache/dotnet-sonarscanner end /d:sonar.token="${{ secrets.SONAR_TOKEN }}"