| name: Coverity Scan |
| on: |
| # Run on every commit to mainline |
| push: |
| branches: main |
| # Allow manual running of the scan |
| workflow_dispatch: |
| |
| env: |
| bashPass: \033[32;1mPASSED - |
| bashInfo: \033[33;1mINFO - |
| bashFail: \033[31;1mFAILED - |
| bashEnd: \033[0m |
| |
| jobs: |
| Coverity-Scan: |
| if: ( github.repository == 'FreeRTOS/FreeRTOS-Kernel' ) |
| name: Coverity Scan |
| runs-on: ubuntu-latest |
| steps: |
| - name: Checkout the Repository |
| uses: actions/checkout@v4.1.1 |
| |
| - env: |
| stepName: Install Build Essentials |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| sudo apt-get -y update |
| sudo apt-get -y install build-essential |
| |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| - env: |
| stepName: Install Coverity Build |
| COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }} |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| wget -nv -q -O "$HOME/cov-analysis.tar.gz" https://scan.coverity.com/download/linux64 --post-data="token=${COVERITY_TOKEN}&project=FreeRTOS-Kernel" |
| |
| EXPECTED_MD5="e4418004b073140d67390cffba79c3b2" |
| GENERATED_MD5=$(md5sum "$HOME/cov-analysis.tar.gz" | awk '{print $1}') |
| |
| if [ "$GENERATED_MD5" = "$EXPECTED_MD5" ]; then |
| tar -zxf "$HOME/cov-analysis.tar.gz" --one-top-level=cov_scan -C "$HOME" |
| echo "cov_scan_path=$HOME/cov_scan/bin" >> $GITHUB_ENV |
| sudo rm -f "$HOME/cov-analysis.tar.gz" |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} " |
| else |
| echo -e "${{ env.bashFail }} MD5 checksum verification failed for cov-analysis.tar.gz ${{ env.bashEnd }}" |
| echo -e "${{ env.bashFail }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| exit -1 |
| fi |
| |
| - env: |
| stepName: Coverity Build |
| COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }} |
| COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }} |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| export PATH="$PATH:${{env.cov_scan_path}}" |
| cmake -S ./examples/cmake_example/ -B build |
| cd build |
| cov-build --dir cov-int make -j |
| # Move the report out of the build directory |
| tar czvf ../gcc_freertos_kernel_sample_build.tgz cov-int |
| |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} " |
| |
| - env: |
| stepName: Upload Coverity Report for Scan |
| COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }} |
| COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }} |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| COV_SCAN_UPLOAD_STATUS=$(curl --form token=${COVERITY_TOKEN} \ |
| --form email=${COVERITY_EMAIL} \ |
| --form file=@gcc_freertos_kernel_sample_build.tgz \ |
| --form version="Mainline" \ |
| --form description="FreeRTOS Kernel Commit Scan" \ |
| https://scan.coverity.com/builds?project=FreeRTOS-Kernel) |
| |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} " |
| echo "${COV_SCAN_UPLOAD_STATUS}" | grep -q -e 'Build successfully submitted' || echo >&2 "Error submitting build for analysis: ${COV_SCAN_UPLOAD_STATUS}" |
| |
| - env: |
| stepName: Coverity Build for SMP FreeRTOS |
| COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }} |
| COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }} |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| export PATH="$PATH:${{env.cov_scan_path}}" |
| cmake -S ./examples/cmake_example/ -B build -DFREERTOS_SMP_EXAMPLE=1 |
| cd build |
| cov-build --dir cov-int make -j |
| # Move the report out of the build directory |
| tar czvf ../gcc_freertos_kernel_smp_sample_build.tgz cov-int |
| |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} " |
| |
| - env: |
| stepName: Upload FreeRTOS SMP Coverity Report for Scan |
| COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }} |
| COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }} |
| shell: bash |
| run: | |
| # ${{ env.stepName }} |
| echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}" |
| |
| COV_SCAN_UPLOAD_STATUS=$(curl --form token=${COVERITY_TOKEN} \ |
| --form email=${COVERITY_EMAIL} \ |
| --form file=@gcc_freertos_kernel_smp_sample_build.tgz \ |
| --form version="Mainline" \ |
| --form description="FreeRTOS Kernel SMP Commit Scan" \ |
| https://scan.coverity.com/builds?project=FreeRTOS-Kernel) |
| |
| echo "::endgroup::" |
| echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} " |
| echo "${COV_SCAN_UPLOAD_STATUS}" | grep -q -e 'Build successfully submitted' || echo >&2 "Error submitting build for analysis: ${COV_SCAN_UPLOAD_STATUS}" |