sonar-cloud.yml 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. name: Sonar Cloud
  2. on:
  3. push:
  4. branches: [ master, 4.x ]
  5. paths-ignore:
  6. - 'Docs/**'
  7. - '**.md'
  8. pull_request:
  9. branches: [ master, 4.x ]
  10. paths-ignore:
  11. - 'Docs/**'
  12. - '**.md'
  13. jobs:
  14. check-secret:
  15. runs-on: ubuntu-latest
  16. outputs:
  17. sonar-token: ${{ steps.sonar-token.outputs.defined }}
  18. steps:
  19. - id: sonar-token
  20. if: ${{ env.SONAR_TOKEN != '' }}
  21. run: echo "defined=true" >> $GITHUB_OUTPUT
  22. env:
  23. SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
  24. build:
  25. name: Build
  26. needs: [check-secret]
  27. if: needs.check-secret.outputs.sonar-token == 'true'
  28. runs-on: ubuntu-latest
  29. env:
  30. BUILD_WRAPPER_OUT_DIR: build_wrapper_output_directory # Directory where build-wrapper output will be placed
  31. CLANG_VERSION: 14
  32. steps:
  33. - uses: actions/checkout@v4
  34. with:
  35. fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis
  36. - name: Install sonar-scanner and build-wrapper
  37. uses: SonarSource/sonarcloud-github-c-cpp@v2
  38. - name: Configure CMake
  39. run: |
  40. cd ${{github.workspace}}/Build/
  41. ./cmake_linux_clang_gcc.sh ReleaseCoverage clang++-${{ env.CLANG_VERSION }}
  42. - name: Run build-wrapper
  43. run: |
  44. build-wrapper-linux-x86-64 --out-dir ${{ env.BUILD_WRAPPER_OUT_DIR }} cmake --build ${{github.workspace}}/Build/Linux_ReleaseCoverage
  45. - name: Run unit tests and create coverage report
  46. run: |
  47. cd ${{github.workspace}}/Build/Linux_ReleaseCoverage/
  48. cmake --build . --target test
  49. llvm-profdata-${{ env.CLANG_VERSION }} merge -sparse default.profraw -o default.profdata
  50. llvm-cov-${{ env.CLANG_VERSION }} show -format=text UnitTests -instr-profile=default.profdata > coverage.txt
  51. - name: Run sonar-scanner
  52. env:
  53. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  54. SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
  55. run: |
  56. sonar-scanner --define sonar.cfamily.build-wrapper-output="${{ env.BUILD_WRAPPER_OUT_DIR }}" --define sonar.cfamily.llvm-cov.reportPath="${{github.workspace}}/Build/Linux_ReleaseCoverage/coverage.txt"