coverity: allow running on macOS

For completeness' sake, let's add support for submitting macOS builds to
Coverity Scan.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Johannes Schindelin
2023-09-25 11:51:01 +00:00
committed by Junio C Hamano
parent d3c3ffa624
commit c13d2adf8b

View File

@@ -43,7 +43,7 @@ jobs:
if: contains(matrix.os, 'windows') if: contains(matrix.os, 'windows')
uses: git-for-windows/setup-git-for-windows-sdk@v1 uses: git-for-windows/setup-git-for-windows-sdk@v1
- run: ci/install-dependencies.sh - run: ci/install-dependencies.sh
if: contains(matrix.os, 'ubuntu') if: contains(matrix.os, 'ubuntu') || contains(matrix.os, 'macos')
env: env:
runs_on_pool: ${{ matrix.os }} runs_on_pool: ${{ matrix.os }}
@@ -56,10 +56,17 @@ jobs:
*windows*) *windows*)
COVERITY_PLATFORM=win64 COVERITY_PLATFORM=win64
COVERITY_TOOL_FILENAME=cov-analysis.zip COVERITY_TOOL_FILENAME=cov-analysis.zip
MAKEFLAGS=-j$(nproc)
;;
*macos*)
COVERITY_PLATFORM=macOSX
COVERITY_TOOL_FILENAME=cov-analysis.dmg
MAKEFLAGS=-j$(sysctl -n hw.physicalcpu)
;; ;;
*ubuntu*) *ubuntu*)
COVERITY_PLATFORM=linux64 COVERITY_PLATFORM=linux64
COVERITY_TOOL_FILENAME=cov-analysis.tgz COVERITY_TOOL_FILENAME=cov-analysis.tgz
MAKEFLAGS=-j$(nproc)
;; ;;
*) *)
echo '::error::unhandled OS ${{ matrix.os }}' >&2 echo '::error::unhandled OS ${{ matrix.os }}' >&2
@@ -68,6 +75,7 @@ jobs:
esac esac
echo "COVERITY_PLATFORM=$COVERITY_PLATFORM" >>$GITHUB_ENV echo "COVERITY_PLATFORM=$COVERITY_PLATFORM" >>$GITHUB_ENV
echo "COVERITY_TOOL_FILENAME=$COVERITY_TOOL_FILENAME" >>$GITHUB_ENV echo "COVERITY_TOOL_FILENAME=$COVERITY_TOOL_FILENAME" >>$GITHUB_ENV
echo "MAKEFLAGS=$MAKEFLAGS" >>$GITHUB_ENV
MD5=$(curl https://scan.coverity.com/download/$COVERITY_LANGUAGE/$COVERITY_PLATFORM \ MD5=$(curl https://scan.coverity.com/download/$COVERITY_LANGUAGE/$COVERITY_PLATFORM \
--fail \ --fail \
--form token='${{ secrets.COVERITY_SCAN_TOKEN }}' \ --form token='${{ secrets.COVERITY_SCAN_TOKEN }}' \
@@ -99,6 +107,16 @@ jobs:
mkdir $RUNNER_TEMP/cov-analysis && mkdir $RUNNER_TEMP/cov-analysis &&
tar -xzf $RUNNER_TEMP/$COVERITY_TOOL_FILENAME --strip 1 -C $RUNNER_TEMP/cov-analysis tar -xzf $RUNNER_TEMP/$COVERITY_TOOL_FILENAME --strip 1 -C $RUNNER_TEMP/cov-analysis
;; ;;
*.dmg)
cd $RUNNER_TEMP &&
attach="$(hdiutil attach $COVERITY_TOOL_FILENAME)" &&
volume="$(echo "$attach" | cut -f 3 | grep /Volumes/)" &&
mkdir cov-analysis &&
cd cov-analysis &&
sh "$volume"/cov-analysis-macosx-*.sh &&
ls -l &&
hdiutil detach "$volume"
;;
*.zip) *.zip)
cd $RUNNER_TEMP && cd $RUNNER_TEMP &&
mkdir cov-analysis-tmp && mkdir cov-analysis-tmp &&
@@ -120,7 +138,7 @@ jobs:
run: | run: |
export PATH="$RUNNER_TEMP/cov-analysis/bin:$PATH" && export PATH="$RUNNER_TEMP/cov-analysis/bin:$PATH" &&
cov-configure --gcc && cov-configure --gcc &&
cov-build --dir cov-int make -j$(nproc) cov-build --dir cov-int make
- name: package the build - name: package the build
run: tar -czvf cov-int.tgz cov-int run: tar -czvf cov-int.tgz cov-int
- name: submit the build to Coverity Scan - name: submit the build to Coverity Scan