diff --git a/.github/workflows/sonarcloud.yml b/.github/workflows/sonarcloud.yml new file mode 100644 index 000000000..de573c6af --- /dev/null +++ b/.github/workflows/sonarcloud.yml @@ -0,0 +1,64 @@ +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: Docker compose up + run: docker compose up -d && sleep 10 + + - 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 }}"