sonar-cloud.yml 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. name: Sonar Cloud
  2. on:
  3. push:
  4. branches: [ master ]
  5. paths-ignore:
  6. - 'Docs/**'
  7. - '**.md'
  8. pull_request:
  9. branches: [ master ]
  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. SONAR_SCANNER_VERSION: 4.7.0.2747
  31. SONAR_SERVER_URL: "https://sonarcloud.io"
  32. BUILD_WRAPPER_OUT_DIR: build_wrapper_output_directory # Directory where build-wrapper output will be placed
  33. CLANG_VERSION: 12
  34. steps:
  35. - uses: actions/checkout@v3
  36. with:
  37. fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis
  38. - name: Set up JDK 11
  39. uses: actions/setup-java@v3
  40. with:
  41. distribution: 'zulu'
  42. java-version: '11'
  43. java-package: jdk
  44. - name: Download and set up sonar-scanner
  45. env:
  46. SONAR_SCANNER_DOWNLOAD_URL: https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-${{ env.SONAR_SCANNER_VERSION }}-linux.zip
  47. run: |
  48. mkdir -p $HOME/.sonar
  49. curl -sSLo $HOME/.sonar/sonar-scanner.zip ${{ env.SONAR_SCANNER_DOWNLOAD_URL }}
  50. unzip -o $HOME/.sonar/sonar-scanner.zip -d $HOME/.sonar/
  51. echo "$HOME/.sonar/sonar-scanner-${{ env.SONAR_SCANNER_VERSION }}-linux/bin" >> $GITHUB_PATH
  52. - name: Download and set up build-wrapper
  53. env:
  54. BUILD_WRAPPER_DOWNLOAD_URL: ${{ env.SONAR_SERVER_URL }}/static/cpp/build-wrapper-linux-x86.zip
  55. run: |
  56. curl -sSLo $HOME/.sonar/build-wrapper-linux-x86.zip ${{ env.BUILD_WRAPPER_DOWNLOAD_URL }}
  57. unzip -o $HOME/.sonar/build-wrapper-linux-x86.zip -d $HOME/.sonar/
  58. echo "$HOME/.sonar/build-wrapper-linux-x86" >> $GITHUB_PATH
  59. - name: Configure CMake
  60. run: |
  61. cd ${{github.workspace}}/Build/
  62. ./cmake_linux_clang_gcc.sh ReleaseCoverage clang++-${{ env.CLANG_VERSION }}
  63. - name: Run build-wrapper
  64. run: |
  65. build-wrapper-linux-x86-64 --out-dir ${{ env.BUILD_WRAPPER_OUT_DIR }} cmake --build ${{github.workspace}}/Build/Linux_ReleaseCoverage
  66. - name: Run unit tests and create coverage report
  67. run: |
  68. cd ${{github.workspace}}/Build/Linux_ReleaseCoverage/
  69. cmake --build . --target test
  70. llvm-profdata-${{ env.CLANG_VERSION }} merge -sparse default.profraw -o default.profdata
  71. llvm-cov-${{ env.CLANG_VERSION }} show -format=text UnitTests -instr-profile=default.profdata > coverage.txt
  72. - name: Run sonar-scanner
  73. env:
  74. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  75. SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
  76. run: |
  77. sonar-scanner --define sonar.host.url="${{ env.SONAR_SERVER_URL }}" --define sonar.cfamily.build-wrapper-output="${{ env.BUILD_WRAPPER_OUT_DIR }}" --define sonar.cfamily.llvm-cov.reportPath="${{github.workspace}}/Build/Linux_ReleaseCoverage/coverage.txt"