3 # Run on every commit to mainline
6 # Allow manual running of the scan
10 bashPass: \033[32;1mPASSED -
11 bashInfo: \033[33;1mINFO -
12 bashFail: \033[31;1mFAILED -
17 if: ( github.repository == 'FreeRTOS/FreeRTOS-Kernel' )
19 runs-on: ubuntu-latest
21 - name: Checkout the Repository
22 uses: actions/checkout@v4.1.1
25 stepName: Install Build Essentials
29 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
31 sudo apt-get -y update
32 sudo apt-get -y install build-essential
35 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }}"
38 stepName: Install Coverity Build
39 COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
43 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
45 wget -nv -qO- https://scan.coverity.com/download/linux64 --post-data "token=${COVERITY_TOKEN}&project=FreeRTOS-Kernel" | tar -zx --one-top-level=cov_scan --strip-components 1
46 echo "cov_scan_path=$(pwd)/cov_scan/bin" >> $GITHUB_ENV
49 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} "
52 stepName: Coverity Build
53 COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
54 COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }}
58 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
60 export PATH="$PATH:${{env.cov_scan_path}}"
61 cmake -S ./examples/cmake_example/ -B build
63 cov-build --dir cov-int make -j
64 # Move the report out of the build directory
65 tar czvf ../gcc_freertos_kernel_sample_build.tgz cov-int
68 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} "
71 stepName: Upload Coverity Report for Scan
72 COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
73 COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }}
77 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
79 COV_SCAN_UPLOAD_STATUS=$(curl --form token=${COVERITY_TOKEN} \
80 --form email=${COVERITY_EMAIL} \
81 --form file=@gcc_freertos_kernel_sample_build.tgz \
82 --form version="Mainline" \
83 --form description="FreeRTOS Kernel Commit Scan" \
84 https://scan.coverity.com/builds?project=FreeRTOS-Kernel)
87 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} "
88 echo "${COV_SCAN_UPLOAD_STATUS}" | grep -q -e 'Build successfully submitted' || echo >&2 "Error submitting build for analysis: ${COV_SCAN_UPLOAD_STATUS}"
91 stepName: Coverity Build for SMP FreeRTOS
92 COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
93 COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }}
97 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
99 export PATH="$PATH:${{env.cov_scan_path}}"
100 cmake -S ./examples/cmake_example/ -B build -DFREERTOS_SMP_EXAMPLE=1
102 cov-build --dir cov-int make -j
103 # Move the report out of the build directory
104 tar czvf ../gcc_freertos_kernel_smp_sample_build.tgz cov-int
107 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} "
110 stepName: Upload FreeRTOS SMP Coverity Report for Scan
111 COVERITY_TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
112 COVERITY_EMAIL: ${{ secrets.COVERITY_SCAN_EMAIL }}
115 # ${{ env.stepName }}
116 echo -e "::group::${{ env.bashInfo }} ${{ env.stepName }} ${{ env.bashEnd }}"
118 COV_SCAN_UPLOAD_STATUS=$(curl --form token=${COVERITY_TOKEN} \
119 --form email=${COVERITY_EMAIL} \
120 --form file=@gcc_freertos_kernel_smp_sample_build.tgz \
121 --form version="Mainline" \
122 --form description="FreeRTOS Kernel SMP Commit Scan" \
123 https://scan.coverity.com/builds?project=FreeRTOS-Kernel)
126 echo -e "${{ env.bashPass }} ${{ env.stepName }} ${{ env.bashEnd }} "
127 echo "${COV_SCAN_UPLOAD_STATUS}" | grep -q -e 'Build successfully submitted' || echo >&2 "Error submitting build for analysis: ${COV_SCAN_UPLOAD_STATUS}"