#!/bin/bash # FD.io VPP Coverity build script # # Builds VPP with the Coverity wrapper and if successful submits # it to the Coverity scan service for processing. # # Several environment variables are needed: # # COVERITY_TOKEN The Coverity Scan API token for this project # COVERITY_TOOLS The location of the Coverity tools # # The coverity tools can be fetched with: # wget https://scan.coverity.com/download/linux64 \ # --post-data "token=${COVERITY_TOKEN}&project=fd.io+VPP" \ # -O coverity_tool.tgz set -ex token=${COVERITY_TOKEN} email=vpp-committers@lists.fd.io project="fd.io VPP" project_encoded="fd.io+VPP" url=https://scan.coverity.com # Cosmetic labels for the Coverity build logs export COV_HOST=$(hostname -f) export COV_USER=vpp # Work out where the root and build-root are script_dir=$(readlink -f $(dirname $0)) root_dir=$(readlink -f "${script_dir}/../..") build_dir=$(readlink -f "${script_dir}/../../build-root") # Location for Coverity things covdir="${build_dir}/cov-int" COVERITY_TOOLS="${COVERITY_TOOLS-/scratch/cov-analysis-latest}" # Before we run the build, check that we can submit one check=$(curl -s --form project="${project}" \ --form token="${token}" "${url}/api/upload_permitted") if [ "${check}" = "Access denied" ]; then echo "Bad token or project name." exit 1 fi if [ "${check}" != '{"upload_permitted":true}' ]; then echo "Upload not permitted; stop now..." exit 1 fi version=$(git describe) # Run the build cd "${root_dir}" "${COVERITY_TOOLS}/bin/cov-build" --dir "${covdir}" make bootstrap build-coverity cd "${build_dir}" # Tar the build artifacts that scan wants tar -czf fd.io-vpp.tgz "$(basename ${covdir})" rm -rf "${covdir}" # Submit the build echo curl --form token="${token}" \ --form email="${email}" \ --form file=@fd.io-vpp.tgz \ --form version="${version}" \ --form description="master:${version}" \ "${url}/builds?project=${project_encoded}" # All done!