Nightly Coverity Scan #666
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Nightly Coverity Scan | |
on: | |
schedule: | |
# Every night, at midnight | |
- cron: '0 0 * * *' | |
env: | |
APT_PACKAGES: >- | |
abi-compliance-checker | |
abi-dumper | |
build-essential | |
debhelper | |
fakeroot | |
gcc | |
git | |
libnl-3-200 libnl-3-dev libnl-route-3-200 libnl-route-3-dev | |
libnuma-dev | |
libudev-dev | |
uuid-dev | |
make | |
ninja-build | |
pandoc | |
pkg-config | |
python-is-python3 | |
rpm | |
sparse | |
valgrind | |
wget | |
OFI_PROVIDER_FLAGS: >- | |
--enable-efa=rdma-core/build | |
--enable-mrail | |
--enable-psm3=rdma-core/build | |
--enable-rxd | |
--enable-rxm | |
--enable-shm | |
--enable-tcp | |
--enable-udp | |
--enable-usnic | |
--enable-verbs=rdma-core/build | |
--enable-sm2 | |
RDMA_CORE_PATH: 'rdma-core/build' | |
RDMA_CORE_VERSION: v34.1 | |
jobs: | |
coverity: | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Install dependencies (Linux) | |
run: | | |
sudo apt-get update | |
sudo apt-get install -y ${{ env.APT_PACKAGES }} | |
- uses: actions/checkout@v4 | |
- name: Download Coverity tools | |
run: | | |
wget https://scan.coverity.com/download/linux64 --post-data "token=${{ secrets.COVERITY_SCAN_TOKEN }}&project=ofiwg%2Flibfabric" -O coverity_tool.tgz | |
mkdir cov-analysis-linux64-2020.09 | |
tar xzf coverity_tool.tgz --strip 1 -C cov-analysis-linux64-2020.09 | |
- name: Run Coverity Build | |
run: | | |
set -x | |
git clone --depth 1 -b ${{ env.RDMA_CORE_VERSION }} https://github.com/linux-rdma/rdma-core.git | |
pushd rdma-core; bash build.sh; popd | |
export LD_LIBRARY_PATH="${{ env.RDMA_CORE_PATH }}/lib:$LD_LIBRARY_PATH" | |
# We use a compiler extension that supports broader complex type | |
# definitions than what's defined in C99 standard (which only defines | |
# complex floats). For some reason, the version of GCC in this | |
# container does not provide that extension, but clang does. Until we | |
# know better, this action will use the clang compiler to generate the | |
# cov-build bundle needed for the coverity scan. | |
export PATH=$PWD/cov-analysis-linux64-2020.09/bin:$PATH | |
cov-configure --clang | |
./autogen.sh | |
./configure --prefix=$PWD/install ${{ env.OFI_PROVIDER_FLAGS }} CC=clang | |
cov-build --dir cov-int make | |
make install | |
- name: Submit results | |
run: | | |
tar czvf libfabric.tgz cov-int | |
curl \ | |
--form token=${{ secrets.COVERITY_SCAN_TOKEN }} \ | |
--form [email protected] \ | |
--form [email protected] \ | |
--form version="main" \ | |
--form description="`$PWD/install/bin/fi_info -l`" \ | |
https://scan.coverity.com/builds?project=ofiwg%2Flibfabric | |
- name: Upload build logs | |
uses: actions/upload-artifact@v3 | |
with: | |
name: coverity-build-log.txt | |
path: cov-int/build-log.txt |