sonar-cloud.yml 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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 "::set-output name=defined::true"
  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@v2
  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@v1
  40. with:
  41. java-version: 11
  42. - name: Download and set up sonar-scanner
  43. env:
  44. SONAR_SCANNER_DOWNLOAD_URL: https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-${{ env.SONAR_SCANNER_VERSION }}-linux.zip
  45. run: |
  46. mkdir -p $HOME/.sonar
  47. curl -sSLo $HOME/.sonar/sonar-scanner.zip ${{ env.SONAR_SCANNER_DOWNLOAD_URL }}
  48. unzip -o $HOME/.sonar/sonar-scanner.zip -d $HOME/.sonar/
  49. echo "$HOME/.sonar/sonar-scanner-${{ env.SONAR_SCANNER_VERSION }}-linux/bin" >> $GITHUB_PATH
  50. - name: Download and set up build-wrapper
  51. env:
  52. BUILD_WRAPPER_DOWNLOAD_URL: ${{ env.SONAR_SERVER_URL }}/static/cpp/build-wrapper-linux-x86.zip
  53. run: |
  54. curl -sSLo $HOME/.sonar/build-wrapper-linux-x86.zip ${{ env.BUILD_WRAPPER_DOWNLOAD_URL }}
  55. unzip -o $HOME/.sonar/build-wrapper-linux-x86.zip -d $HOME/.sonar/
  56. echo "$HOME/.sonar/build-wrapper-linux-x86" >> $GITHUB_PATH
  57. - name: Configure CMake
  58. run: |
  59. cd ${{github.workspace}}/Build/
  60. ./cmake_linux_clang_gcc.sh ReleaseCoverage clang++-${{ env.CLANG_VERSION }}
  61. - name: Run build-wrapper
  62. run: |
  63. build-wrapper-linux-x86-64 --out-dir ${{ env.BUILD_WRAPPER_OUT_DIR }} cmake --build ${{github.workspace}}/Build/Linux_ReleaseCoverage
  64. - name: Run unit tests and create coverage report
  65. run: |
  66. cd ${{github.workspace}}/Build/Linux_ReleaseCoverage/
  67. cmake --build . --target test
  68. llvm-profdata-${{ env.CLANG_VERSION }} merge -sparse default.profraw -o default.profdata
  69. llvm-cov-${{ env.CLANG_VERSION }} show -format=text UnitTests -instr-profile=default.profdata > coverage.txt
  70. - name: Run sonar-scanner
  71. env:
  72. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  73. SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
  74. run: |
  75. 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"