Add Coverity Scan target to .travis.yml
Signed-off-by: Jeroen Koekkoek <jeroen@koekkoek.nl>
This commit is contained in:
parent
aa2715f4fe
commit
e3428ad1d8
1 changed files with 119 additions and 69 deletions
188
.travis.yml
188
.travis.yml
|
@ -1,8 +1,41 @@
|
||||||
language: c
|
language: c
|
||||||
|
|
||||||
# Platform descriptions
|
# Coverity Scan can be configured through Travis addons, but this allows for
|
||||||
# NOTE: These can be used in creating the build matrix by making use of the
|
# more control over the build instructions and does not require the addition
|
||||||
# anchor/alias YAML features.
|
# of a coverity_scan branch in the repository. travisci_build_coverity_scan.sh
|
||||||
|
# does more checks before it decides to download Coverity (around 500M), but
|
||||||
|
# these instructions assume Coverity Scan is not installed if the directory
|
||||||
|
# does not exist and expects the download to fail if the token is incorrect.
|
||||||
|
# Coverity Scan quota are not checked as the Coverity enabled build must only
|
||||||
|
# run from cron.
|
||||||
|
install_coverity: &install_coverity
|
||||||
|
if [ -n "${COVERITY_SCAN}" ]; then
|
||||||
|
COVERITY_DIR="/tmp/coverity-scan-analysis";
|
||||||
|
COVERITY_ARCHIVE="/tmp/cov-analysis-${COV_PLATFORM}.tgz";
|
||||||
|
test ! -d "${COVERITY_DIR}" &&
|
||||||
|
mkdir -p "${COVERITY_DIR}" &&
|
||||||
|
curl -f -s -F project="${TRAVIS_REPO_SLUG}"
|
||||||
|
-F token="${COVERITY_SCAN_TOKEN}"
|
||||||
|
-o "${COVERITY_ARCHIVE}"
|
||||||
|
"https://scan.coverity.com/download/cxx/${COV_PLATFORM}" &&
|
||||||
|
tar -xzf "${COVERITY_ARCHIVE}" -C "${COVERITY_DIR}";
|
||||||
|
COVERITY_ANALYSIS=$(find "${COVERITY_DIR}" -type d -name "cov-analysis*");
|
||||||
|
eval "export PATH=\"${PATH}:${COVERITY_ANALYSIS}/bin\"";
|
||||||
|
eval "export SCAN_BUILD=\"cov-build --dir cov-int\"";
|
||||||
|
cov-configure --comptype ${COV_COMPTYPE} --compiler ${CC} --template;
|
||||||
|
fi
|
||||||
|
|
||||||
|
submit_to_coverity_scan: &submit_to_coverity_scan
|
||||||
|
if [ -n "${COVERITY_SCAN}" ]; then
|
||||||
|
tar -czf analysis-results.tgz cov-int &&
|
||||||
|
curl -f -v -F project="${TRAVIS_REPO_SLUG}"
|
||||||
|
-F token="${COVERITY_SCAN_TOKEN}"
|
||||||
|
-F file=@analysis-results.tgz
|
||||||
|
-F version=$(git rev-parse --short HEAD)
|
||||||
|
-F description="Travis CI build"
|
||||||
|
"https://scan.coverity.com/builds";
|
||||||
|
fi
|
||||||
|
|
||||||
linux_gcc8: &linux_gcc8
|
linux_gcc8: &linux_gcc8
|
||||||
os: linux
|
os: linux
|
||||||
dist: xenial
|
dist: xenial
|
||||||
|
@ -12,6 +45,13 @@ linux_gcc8: &linux_gcc8
|
||||||
update: true
|
update: true
|
||||||
sources: [ ubuntu-toolchain-r-test ]
|
sources: [ ubuntu-toolchain-r-test ]
|
||||||
packages: [ gcc-8 g++-8 ]
|
packages: [ gcc-8 g++-8 ]
|
||||||
|
before_install:
|
||||||
|
- eval "export CC=gcc-8"
|
||||||
|
- eval "export CXX=g++-8"
|
||||||
|
- eval "export COV_COMPTYPE=gcc COV_PLATFORM=linux64"
|
||||||
|
install:
|
||||||
|
- *install_coverity
|
||||||
|
- pip install conan --upgrade --user
|
||||||
|
|
||||||
linux_clang: &linux_clang
|
linux_clang: &linux_clang
|
||||||
os: linux
|
os: linux
|
||||||
|
@ -20,6 +60,12 @@ linux_clang: &linux_clang
|
||||||
addons:
|
addons:
|
||||||
apt:
|
apt:
|
||||||
update: true
|
update: true
|
||||||
|
before_install:
|
||||||
|
- eval "export CC=clang"
|
||||||
|
- eval "export CXX=clang++"
|
||||||
|
- eval "export COV_COMPTYPE=clang COV_PLATFORM=linux64"
|
||||||
|
install:
|
||||||
|
- pip install conan --upgrade --user
|
||||||
|
|
||||||
osx_xcode10_1: &osx_xcode10_1
|
osx_xcode10_1: &osx_xcode10_1
|
||||||
os: osx
|
os: osx
|
||||||
|
@ -29,86 +75,86 @@ osx_xcode10_1: &osx_xcode10_1
|
||||||
homebrew:
|
homebrew:
|
||||||
packages:
|
packages:
|
||||||
- pyenv-virtualenv
|
- pyenv-virtualenv
|
||||||
|
before_install:
|
||||||
|
- eval "export CC=clang"
|
||||||
|
- eval "export CXX=clang++"
|
||||||
|
- eval "export COV_COMPTYPE=clang COV_PLATFORM=macOSX"
|
||||||
|
install:
|
||||||
|
- eval "$(pyenv init -)"
|
||||||
|
- pyenv virtualenv conan
|
||||||
|
- pyenv rehash
|
||||||
|
- pyenv activate conan
|
||||||
|
- pip install conan --upgrade
|
||||||
|
|
||||||
windows_vs2017: &windows_vs2017
|
windows_vs2017: &windows_vs2017
|
||||||
os: windows
|
os: windows
|
||||||
|
# Conan will automatically determine the best compiler for a given platform
|
||||||
|
# based on educated guesses. The first check is based on the CC and CXX
|
||||||
|
# environment variables, the second (on Windows) is to check if Microsoft
|
||||||
|
# Visual Studio is installed. On Travis CC and CXX are set to gcc on
|
||||||
|
# Microsoft Windows targets as well, this has the undesired effect that MSVC
|
||||||
|
# is not detected, unsetting CC and CXX solves that problem.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# !!! IMPORTANT !!!
|
||||||
|
#
|
||||||
|
# Microsoft Windows instances freeze at "install:" if secure environment
|
||||||
|
# variables are used. There is no option to export secrets only for
|
||||||
|
# specified platforms. The "filter_secrets: false" option is used to disable
|
||||||
|
# the filter for Microsoft Windows instances. This is not an issue if the
|
||||||
|
# secret is removed from the environment at the earliest opportunity, before
|
||||||
|
# risk of exposure, as secrets are always removed from the environment for
|
||||||
|
# pull requests and are still filtered when exported to the environment. The
|
||||||
|
# secret of course will not be available for Microsoft Windows builds, but
|
||||||
|
# for Coverity Scan, that is fine.
|
||||||
|
filter_secrets: false
|
||||||
|
before_install:
|
||||||
|
- eval "unset COVERITY_SCAN_TOKEN"
|
||||||
|
- eval "unset CC"
|
||||||
|
- eval "unset CXX"
|
||||||
|
- eval "export COV_COMPTYPE=msvc COV_PLATFORM=win64"
|
||||||
|
- JAVA_HOME=$(find "/c/Program Files/Android/jdk/" -name "*openjdk*" | sort | head -n 1)
|
||||||
|
- export JAVA_HOME
|
||||||
|
- export PATH="${PATH}:${JAVA_HOME}/bin"
|
||||||
|
# Windows targets in Travis are still very much in beta and Python is not yet
|
||||||
|
# available and installation of Python through Chocolaty does not work well.
|
||||||
|
# The real fix is to wait until Python and pip are both available on the
|
||||||
|
# target. Until then download Conan from the official website and simply add
|
||||||
|
# the extracted folder to the path.
|
||||||
|
install:
|
||||||
|
- choco install innoextract
|
||||||
|
- choco install maven --ignore-dependencies
|
||||||
|
- wget -q https://dl.bintray.com/conan/installers/conan-win-64_1_10_0.exe
|
||||||
|
- innoextract conan-win-64_1_10_0.exe
|
||||||
|
- eval "export PATH=\"$(pwd)/app/conan:${PATH}\""
|
||||||
|
|
||||||
matrix:
|
jobs:
|
||||||
include:
|
include:
|
||||||
- <<: *linux_gcc8
|
- <<: *linux_gcc8
|
||||||
env: [ BUILD_TYPE=Debug, C_COMPILER=gcc-8, CXX_COMPILER=g++-8, USE_SANITIZER=none ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Debug, GENERATOR="Unix Makefiles", COVERITY_SCAN=true ]
|
||||||
|
if: type = cron
|
||||||
- <<: *linux_gcc8
|
- <<: *linux_gcc8
|
||||||
env: [ BUILD_TYPE=Release, C_COMPILER=gcc-8, CXX_COMPILER=g++-8, USE_SANITIZER=none ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Debug, GENERATOR="Unix Makefiles" ]
|
||||||
|
- <<: *linux_gcc8
|
||||||
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Release, GENERATOR="Unix Makefiles" ]
|
||||||
- <<: *linux_clang
|
- <<: *linux_clang
|
||||||
env: [ BUILD_TYPE=Debug, C_COMPILER=clang, CXX_COMPILER=clang++, USE_SANITIZER=address ]
|
env: [ ARCH=x86_64, ASAN=address, BUILD_TYPE=Debug, GENERATOR="Unix Makefiles" ]
|
||||||
- <<: *linux_clang
|
- <<: *linux_clang
|
||||||
env: [ BUILD_TYPE=Release, C_COMPILER=clang, CXX_COMPILER=clang++, USE_SANITIZER=none ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Release, GENERATOR="Unix Makefiles" ]
|
||||||
- <<: *osx_xcode10_1
|
- <<: *osx_xcode10_1
|
||||||
env: [ BUILD_TYPE=Debug, C_COMPILER=clang, CXX_COMPILER=clang++, USE_SANITIZER=address ]
|
env: [ ARCH=x86_64, ASAN=address, BUILD_TYPE=Debug, GENERATOR="Unix Makefiles" ]
|
||||||
- <<: *osx_xcode10_1
|
- <<: *osx_xcode10_1
|
||||||
env: [ BUILD_TYPE=Release, C_COMPILER=clang, CXX_COMPILER=clang++, USE_SANITIZER=none ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Release, GENERATOR="Unix Makefiles" ]
|
||||||
- <<: *windows_vs2017
|
- <<: *windows_vs2017
|
||||||
env: [ ARCH=x86, BUILD_TYPE=Debug, GENERATOR="Visual Studio 15 2017" ]
|
env: [ ARCH=x86, ASAN=none, BUILD_TYPE=Debug, GENERATOR="Visual Studio 15 2017" ]
|
||||||
- <<: *windows_vs2017
|
- <<: *windows_vs2017
|
||||||
env: [ ARCH=x86_64, BUILD_TYPE=Debug, GENERATOR="Visual Studio 15 2017" ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Debug, GENERATOR="Visual Studio 15 2017 Win64" ]
|
||||||
- <<: *windows_vs2017
|
- <<: *windows_vs2017
|
||||||
env: [ ARCH=x86_64, BUILD_TYPE=Release, GENERATOR="Visual Studio 15 2017" ]
|
env: [ ARCH=x86_64, ASAN=none, BUILD_TYPE=Release, GENERATOR="Visual Studio 15 2017 Win64" ]
|
||||||
|
|
||||||
# Conan will automatically determine the best compiler for a given platform
|
|
||||||
# based on educated guesses. The first check is based on the CC and CXX
|
|
||||||
# environment variables, the second (on Windows) is to check if Microsoft
|
|
||||||
# Visual Studio is installed. On Travis CC and CXX are set to gcc on Microsoft
|
|
||||||
# Windows targets as well, this has the undesired effect that MSVC is not
|
|
||||||
# detected, unsetting CC and CXX solves that problem.
|
|
||||||
before_install:
|
|
||||||
- if [ "${TRAVIS_OS_NAME}" = "windows" ]; then
|
|
||||||
eval "unset CC";
|
|
||||||
eval "unset CXX";
|
|
||||||
JAVA_HOME=$(find "/c/Program Files/Android/jdk/" -name "*openjdk*" | sort | head -n 1);
|
|
||||||
export JAVA_HOME;
|
|
||||||
export PATH="${PATH}:${JAVA_HOME}/bin";
|
|
||||||
else
|
|
||||||
eval "export CC=${C_COMPILER}";
|
|
||||||
eval "export CXX=${CXX_COMPILER}";
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Windows targets in Travis are still very much in beta and Python is not yet
|
|
||||||
# available and installation of Python through Chocolaty does not work well.
|
|
||||||
# The real fix is to wait until Python and pip are both available on the
|
|
||||||
# target. Until then download Conan from the official website and simply add
|
|
||||||
# the extracted folder to the path.
|
|
||||||
install:
|
|
||||||
- if [ "${TRAVIS_OS_NAME}" = "windows" ]; then
|
|
||||||
choco install innoextract;
|
|
||||||
choco install maven --ignore-dependencies;
|
|
||||||
wget -q https://dl.bintray.com/conan/installers/conan-win-64_1_10_0.exe;
|
|
||||||
innoextract conan-win-64_1_10_0.exe;
|
|
||||||
eval "export PATH=\"$(pwd)/app/conan:${PATH}\"";
|
|
||||||
elif [ "${TRAVIS_OS_NAME}" = "osx" ]; then
|
|
||||||
eval "$(pyenv init -)";
|
|
||||||
pyenv virtualenv conan;
|
|
||||||
pyenv rehash;
|
|
||||||
pyenv activate conan;
|
|
||||||
pip install conan --upgrade;
|
|
||||||
else
|
|
||||||
pip install conan --upgrade --user;
|
|
||||||
fi
|
|
||||||
- conan profile new default --detect
|
|
||||||
|
|
||||||
before_script:
|
before_script:
|
||||||
|
- conan profile new default --detect
|
||||||
- conan remote add bincrafters https://api.bintray.com/conan/bincrafters/public-conan
|
- conan remote add bincrafters https://api.bintray.com/conan/bincrafters/public-conan
|
||||||
- conan profile get settings.arch default
|
|
||||||
- if [ -z "${ARCH}" ]; then
|
|
||||||
eval "export ARCH=\"$(conan profile get settings.arch default)\"";
|
|
||||||
fi
|
|
||||||
- if [ "${TRAVIS_OS_NAME}" = "windows" ]; then
|
|
||||||
GENERATOR_ARCH=$(if [ "${ARCH}" = "x86_64" ]; then echo " Win64"; fi);
|
|
||||||
eval "export GENERATOR=\"${GENERATOR}${GENERATOR_ARCH}\"";
|
|
||||||
eval "export USE_SANITIZER=none";
|
|
||||||
else
|
|
||||||
eval "export GENERATOR=\"Unix Makefiles\"";
|
|
||||||
fi
|
|
||||||
- export
|
|
||||||
|
|
||||||
script:
|
script:
|
||||||
- mkdir build
|
- mkdir build
|
||||||
|
@ -116,12 +162,12 @@ script:
|
||||||
- conan install -b missing -s arch=${ARCH} -s build_type=${BUILD_TYPE} ..
|
- conan install -b missing -s arch=${ARCH} -s build_type=${BUILD_TYPE} ..
|
||||||
- cmake -DCMAKE_BUILD_TYPE=${BUILD_TYPE}
|
- cmake -DCMAKE_BUILD_TYPE=${BUILD_TYPE}
|
||||||
-DCMAKE_INSTALL_PREFIX=$(pwd)/install
|
-DCMAKE_INSTALL_PREFIX=$(pwd)/install
|
||||||
-DUSE_SANITIZER=${USE_SANITIZER}
|
-DUSE_SANITIZER=${ASAN}
|
||||||
-DBUILD_TESTING=on
|
-DBUILD_TESTING=on
|
||||||
-G "${GENERATOR}" ../src
|
-G "${GENERATOR}" ../src
|
||||||
- cmake --build . --config ${BUILD_TYPE} --target install
|
- ${SCAN_BUILD} cmake --build . --config ${BUILD_TYPE} --target install
|
||||||
- CYCLONEDDS_URI='<CycloneDDS><DDSI2E><Internal><EnableExpensiveChecks>all</EnableExpensiveChecks></Internal></DDSI2E></CycloneDDS>' ctest -T test -C ${BUILD_TYPE}
|
- CYCLONEDDS_URI='<CycloneDDS><DDSI2E><Internal><EnableExpensiveChecks>all</EnableExpensiveChecks></Internal></DDSI2E></CycloneDDS>' ctest -T test -C ${BUILD_TYPE}
|
||||||
- if [ "${USE_SANITIZER}" != "none" ]; then
|
- if [ "${ASAN}" != "none" ]; then
|
||||||
CMAKE_LINKER_FLAGS="-DCMAKE_LINKER_FLAGS=-fsanitize=${USE_SANITIZER}";
|
CMAKE_LINKER_FLAGS="-DCMAKE_LINKER_FLAGS=-fsanitize=${USE_SANITIZER}";
|
||||||
CMAKE_C_FLAGS="-DCMAKE_C_FLAGS=-fsanitize=${USE_SANITIZER}";
|
CMAKE_C_FLAGS="-DCMAKE_C_FLAGS=-fsanitize=${USE_SANITIZER}";
|
||||||
fi
|
fi
|
||||||
|
@ -132,4 +178,8 @@ script:
|
||||||
${CMAKE_LINKER_FLAGS}
|
${CMAKE_LINKER_FLAGS}
|
||||||
-G "${GENERATOR}" ..
|
-G "${GENERATOR}" ..
|
||||||
- cmake --build . --config ${BUILD_TYPE}
|
- cmake --build . --config ${BUILD_TYPE}
|
||||||
|
- cd "${TRAVIS_BUILD_DIR}/build"
|
||||||
|
|
||||||
|
#after_success:
|
||||||
|
# - *submit_to_coverity_scan
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue