mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-11-04 11:09:01 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			139 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
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}"
 |