jjb: coverity: escape quotes in gcc fix
[lttng-ci.git] / scripts / common / coverity.sh
CommitLineData
a57a60d9 1#!/bin/bash -exu
87b23e49
MJ
2#
3# Copyright (C) 2015 - Michael Jeanson <mjeanson@efficios.com>
4# Jonathan Rajotte-Julien <jonathan.rajotte-julien@efficios.com>
5#
6# This program is free software: you can redistribute it and/or modify
7# it under the terms of the GNU General Public License as published by
8# the Free Software Foundation, either version 3 of the License, or
9# (at your option) any later version.
10#
11# This program is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14# GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
17# along with this program. If not, see <http://www.gnu.org/licenses/>.
18
19# Coverity settings
e8078c79 20# The project name and token have to be provided trough env variables
87b23e49
MJ
21#COVERITY_SCAN_PROJECT_NAME=""
22#COVERITY_SCAN_TOKEN=""
87b23e49
MJ
23COVERITY_SCAN_DESCRIPTION="Automated CI build"
24COVERITY_SCAN_NOTIFICATION_EMAIL="ci-notification@lists.lttng.org"
25COVERITY_SCAN_BUILD_OPTIONS=""
26#COVERITY_SCAN_BUILD_OPTIONS="--return-emit-failures 8 --parse-error-threshold 85"
27
1f4fba8c
MJ
28SRCDIR="$WORKSPACE/src/${COVERITY_SCAN_PROJECT_NAME}"
29TMPDIR="$WORKSPACE/tmp"
30
87b23e49
MJ
31NPROC=$(nproc)
32PLATFORM=$(uname)
33export CFLAGS="-O0 -g -DDEBUG"
34
1f4fba8c 35TOOL_ARCHIVE="$TMPDIR/cov-analysis-${PLATFORM}.tgz"
87b23e49 36TOOL_URL=https://scan.coverity.com/download/${PLATFORM}
1f4fba8c 37TOOL_BASE="$TMPDIR/coverity-scan-analysis"
87b23e49
MJ
38
39UPLOAD_URL="https://scan.coverity.com/builds"
40SCAN_URL="https://scan.coverity.com"
41
1f4fba8c
MJ
42RESULTS_DIR_NAME="cov-int"
43RESULTS_DIR="$WORKSPACE/$RESULTS_DIR_NAME"
44RESULTS_ARCHIVE=analysis-results.tgz
87b23e49 45
1f4fba8c
MJ
46# Create tmp directory
47rm -rf "$TMPDIR"
48mkdir -p "$TMPDIR"
49
50export TMPDIR
51
52case "$COVERITY_SCAN_PROJECT_NAME" in
53babeltrace)
54 CONF_OPTS="--enable-python-bindings --enable-python-bindings-doc"
e3f027ec 55 BUILD_TYPE="autotools"
1f4fba8c
MJ
56 ;;
57liburcu)
58 CONF_OPTS=""
e3f027ec 59 BUILD_TYPE="autotools"
1f4fba8c
MJ
60 ;;
61lttng-modules)
62 CONF_OPTS=""
e3f027ec 63 BUILD_TYPE="autotools"
1f4fba8c
MJ
64 ;;
65lttng-tools)
66 CONF_OPTS=""
e3f027ec 67 BUILD_TYPE="autotools"
1f4fba8c
MJ
68 ;;
69lttng-ust)
70 CONF_OPTS="--enable-java-agent-all --enable-python-agent"
e3f027ec 71 BUILD_TYPE="autotools"
1f4fba8c
MJ
72 export CLASSPATH="/usr/share/java/log4j-1.2.jar"
73 ;;
e3f027ec 74lttng-scope|ctf-java|libdelorean-java|jabberwocky)
7525e08d 75 CONF_OPTS=""
e3f027ec 76 BUILD_TYPE="maven"
7525e08d
MJ
77 MVN_BIN="$HOME/tools/hudson.tasks.Maven_MavenInstallation/default/bin/mvn"
78 ;;
c0eca50d
MJ
79linux-rseq)
80 CONF_OPTS=""
81 BUILD_TYPE="linux-rseq"
82 ;;
1f4fba8c
MJ
83*)
84 echo "Generic project, no configure options."
85 CONF_OPTS=""
e3f027ec 86 BUILD_TYPE="autotools"
1f4fba8c
MJ
87 ;;
88esac
87b23e49
MJ
89
90# liburcu dependency
91if [ -d "$WORKSPACE/deps/liburcu" ]; then
92 URCU_INCS="$WORKSPACE/deps/liburcu/build/include/"
93 URCU_LIBS="$WORKSPACE/deps/liburcu/build/lib/"
1f4fba8c 94
87b23e49
MJ
95 export CPPFLAGS="-I$URCU_INCS ${CPPFLAGS:-}"
96 export LDFLAGS="-L$URCU_LIBS ${LDFLAGS:-}"
97 export LD_LIBRARY_PATH="$URCU_LIBS:${LD_LIBRARY_PATH:-}"
98fi
99
100
101# lttng-ust dependency
102if [ -d "$WORKSPACE/deps/lttng-ust" ]; then
103 UST_INCS="$WORKSPACE/deps/lttng-ust/build/include/"
104 UST_LIBS="$WORKSPACE/deps/lttng-ust/build/lib/"
1f4fba8c 105
87b23e49
MJ
106 export CPPFLAGS="-I$UST_INCS ${CPPFLAGS:-}"
107 export LDFLAGS="-L$UST_LIBS ${LDFLAGS:-}"
108 export LD_LIBRARY_PATH="$UST_LIBS:${LD_LIBRARY_PATH:-}"
109fi
110
7e942863
MJ
111if [ -d "$WORKSPACE/src/linux" ]; then
112 export KERNELDIR="$WORKSPACE/src/linux"
5122da3c
JR
113fi
114
96e8f697
MJ
115# Hack to get coverity with gcc >= 7
116#
117# We have to define the _Float* types as those are not defined by coverity and as result
118# the codes linking agains those (pretty much anything linking against stdlib.h and math.h)
119# won't be covered.
120echo "
121#ifdef __cplusplus
187bdd07 122extern \"C\" {
96e8f697
MJ
123#endif
124
125#define _Float128 long double
126#define _Float64x long double
127#define _Float64 double
128#define _Float32x double
129#define _Float32 float
130
131#ifdef __cplusplus
132}
133#endif" >> /tmp/coverity.h
134
135export CPPFLAGS="-include /tmp/coverity.h ${CPPFLAGS:-}"
136
87b23e49
MJ
137
138# Verify upload is permitted
e8078c79 139set +x
a57a60d9 140AUTH_RES=$(curl -s --form project="$COVERITY_SCAN_PROJECT_NAME" --form token="$COVERITY_SCAN_TOKEN" $SCAN_URL/api/upload_permitted)
e8078c79 141set -x
87b23e49
MJ
142if [ "$AUTH_RES" = "Access denied" ]; then
143 echo -e "\033[33;1mCoverity Scan API access denied. Check COVERITY_SCAN_PROJECT_NAME and COVERITY_SCAN_TOKEN.\033[0m"
144 exit 1
145else
a57a60d9 146 AUTH=$(echo "$AUTH_RES" | jq .upload_permitted)
87b23e49
MJ
147 if [ "$AUTH" = "true" ]; then
148 echo -e "\033[33;1mCoverity Scan analysis authorized per quota.\033[0m"
149 else
a57a60d9 150 WHEN=$(echo "$AUTH_RES" | jq .next_upload_permitted_at)
87b23e49
MJ
151 echo -e "\033[33;1mCoverity Scan analysis NOT authorized until $WHEN.\033[0m"
152 exit 1
153 fi
154fi
155
156
157# Download Coverity Scan Analysis Tool
a57a60d9
MJ
158if [ ! -d "$TOOL_BASE" ]; then
159 if [ ! -e "$TOOL_ARCHIVE" ]; then
87b23e49 160 echo -e "\033[33;1mDownloading Coverity Scan Analysis Tool...\033[0m"
e8078c79 161 set +x
a57a60d9 162 wget -nv -O "$TOOL_ARCHIVE" "$TOOL_URL" --post-data "project=$COVERITY_SCAN_PROJECT_NAME&token=$COVERITY_SCAN_TOKEN"
e8078c79 163 set -x
87b23e49
MJ
164 fi
165
166 # Extract Coverity Scan Analysis Tool
167 echo -e "\033[33;1mExtracting Coverity Scan Analysis Tool...\033[0m"
a57a60d9
MJ
168 mkdir -p "$TOOL_BASE"
169 cd "$TOOL_BASE" || exit 1
170 tar xzf "$TOOL_ARCHIVE"
87b23e49
MJ
171 cd -
172fi
173
a57a60d9 174TOOL_DIR=$(find "$TOOL_BASE" -type d -name 'cov-analysis*')
87b23e49
MJ
175export PATH=$TOOL_DIR/bin:$PATH
176
1f4fba8c
MJ
177cd "$SRCDIR"
178
a57a60d9 179COVERITY_SCAN_VERSION=$(git describe --always | sed 's|-|.|g')
87b23e49 180
87b23e49
MJ
181# Build
182echo -e "\033[33;1mRunning Coverity Scan Analysis Tool...\033[0m"
e3f027ec
MJ
183case "$BUILD_TYPE" in
184maven)
7525e08d
MJ
185 cov-configure --java
186 cov-build --dir "$RESULTS_DIR" $COVERITY_SCAN_BUILD_OPTIONS "$MVN_BIN" \
187 -s "$MVN_SETTINGS" \
188 -Dmaven.repo.local="$WORKSPACE/.repository" \
189 -Dmaven.compiler.fork=true \
190 -Dmaven.compiler.forceJavaCompilerUse=true \
191 -Dmaven.test.skip=true \
192 -DskipTests \
193 clean verify
194 ;;
e3f027ec 195autotools)
c0eca50d
MJ
196 # Prepare build dir for autotools based projects
197 if [ -f "./bootstrap" ]; then
198 ./bootstrap
199 ./configure $CONF_OPTS
200 fi
201
7525e08d
MJ
202 cov-build --dir "$RESULTS_DIR" $COVERITY_SCAN_BUILD_OPTIONS make -j"$NPROC" V=1
203 ;;
c0eca50d
MJ
204linux-rseq)
205 make defconfig
206 cov-build --dir "$RESULTS_DIR" $COVERITY_SCAN_BUILD_OPTIONS make -j"$NPROC" kernel/rseq.o kernel/cpu_opv.o V=1
207 ;;
e3f027ec
MJ
208*)
209 echo "Unsupported build type: $BUILD_TYPE"
210 exit 1
211 ;;
7525e08d
MJ
212esac
213
214
215
a57a60d9 216cov-import-scm --dir "$RESULTS_DIR" --scm git --log "$RESULTS_DIR/scm_log.txt"
87b23e49 217
1f4fba8c
MJ
218cd "${WORKSPACE}"
219
87b23e49
MJ
220# Tar results
221echo -e "\033[33;1mTarring Coverity Scan Analysis results...\033[0m"
1f4fba8c 222tar czf $RESULTS_ARCHIVE $RESULTS_DIR_NAME
87b23e49
MJ
223
224# Upload results
225echo -e "\033[33;1mUploading Coverity Scan Analysis results...\033[0m"
e8078c79 226set +x
87b23e49
MJ
227response=$(curl \
228 --silent --write-out "\n%{http_code}\n" \
a57a60d9
MJ
229 --form project="$COVERITY_SCAN_PROJECT_NAME" \
230 --form token="$COVERITY_SCAN_TOKEN" \
231 --form email="$COVERITY_SCAN_NOTIFICATION_EMAIL" \
232 --form file=@"$RESULTS_ARCHIVE" \
233 --form version="$COVERITY_SCAN_VERSION" \
234 --form description="$COVERITY_SCAN_DESCRIPTION" \
235 "$UPLOAD_URL")
e8078c79 236set -x
87b23e49 237status_code=$(echo "$response" | sed -n '$p')
e3449c79 238if [ "${status_code:0:1}" == "2" ]; then
7525e08d
MJ
239 echo -e "\033[33;1mCoverity Scan upload successful.\033[0m"
240else
87b23e49
MJ
241 TEXT=$(echo "$response" | sed '$d')
242 echo -e "\033[33;1mCoverity Scan upload failed: $TEXT.\033[0m"
243 exit 1
244fi
a57a60d9
MJ
245
246# EOF
This page took 0.036308 seconds and 4 git commands to generate.