lava: Use custom timeout function for make check
[lttng-ci.git] / scripts / system-tests / run-test-suites.sh
CommitLineData
cf1271bb
JR
1#!/bin/bash -xeu
2#
3# Copyright (C) 2021 - Jonathan Rajotte <jonathan.rajotte-julien@efficios.com>
4#
5# This program is free software: you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as published by
7# the Free Software Foundation, either version 3 of the License, or
8# (at your option) any later version.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18# Version compare functions
19vercomp () {
20 set +u
21 if [[ "$1" == "$2" ]]; then
22 return 0
23 fi
24 local IFS=.
25 local i ver1=($1) ver2=($2)
26 # fill empty fields in ver1 with zeros
27 for ((i=${#ver1[@]}; i<${#ver2[@]}; i++)); do
28 ver1[i]=0
29 done
30 for ((i=0; i<${#ver1[@]}; i++)); do
31 if [[ -z ${ver2[i]} ]]; then
32 # fill empty fields in ver2 with zeros
33 ver2[i]=0
34 fi
35 if ((10#${ver1[i]} > 10#${ver2[i]})); then
36 return 1
37 fi
38 if ((10#${ver1[i]} < 10#${ver2[i]})); then
39 return 2
40 fi
41 done
42 set -u
43 return 0
44}
45
46verlte() {
47 vercomp "$1" "$2"; local res="$?"
48 [ "$res" -eq "0" ] || [ "$res" -eq "2" ]
49}
50
51verlt() {
52 vercomp "$1" "$2"; local res="$?"
53 [ "$res" -eq "2" ]
54}
55
56vergte() {
57 vercomp "$1" "$2"; local res="$?"
58 [ "$res" -eq "0" ] || [ "$res" -eq "1" ]
59}
60
61vergt() {
62 vercomp "$1" "$2"; local res="$?"
63 [ "$res" -eq "1" ]
64}
65
66verne() {
67 vercomp "$1" "$2"; local res="$?"
68 [ "$res" -ne "0" ]
69}
70
046a1ad9 71# shellcheck disable=SC2317
d0ffdf18
KS
72function cleanup
73{
74 timedatectl set-ntp true
4663cfc2
KS
75 # The false dates used in the tests are far in the past
76 # and it may take some time for the ntp update to actually
77 # happen.
78 # If the date is still in the past, it is possible that
79 # subsequent steps will fail (eg. TLS certificates cannot
80 # be validated).
81 while [[ "$(date +%Y)" -lt "2024" ]] ; do
82 sleep 1
83 done
d0ffdf18
KS
84}
85
046a1ad9
KS
86function test_timeout
87{
88 local TIMEOUT=0
89 local TIMEOUT_MINUTES="${1:-90}"
90 shift 1
91 PID=''
92 "${@}" &
93 PID="${!}"
94 while true; do
95 sleep 1m
96 if ! ps -q "${PID}" > /dev/null ; then
97 # The process ID doesn't exist anymore
98 break
99 fi
100 TIMEOUT=$((TIMEOUT+1))
101 if [[ "${TIMEOUT}" -ge "${TIMEOUT_MINUTES}" ]]; then
102 echo "Command '${@}' timed out (${TIMEOUT} minutes) " \
103 "attempting to get backtraces for lttng/babeltrace binaries"
104 apt-get install -y --force-yes gdb
105 # Abort all lttng-sessiond, lttng, lttng-relayd, lttng-consumerd,
106 # and babeltrace process so there are coredumps available.
107 PIDS=$(pgrep 'babeltrace*|[l]ttng*')
108 for P in ${PIDS}; do
109 OUTFILE=$(mktemp -t "backtrace-${P}.XXXXXX")
110 ps -f "${P}" | tee -a "${OUTFILE}"
111 gdb -p "${P}" --batch -ex 'thread apply all bt' 2>&1 | tee -a "${OUTFILE}"
112 mv "${OUTFILE}" /tmp/coredump/
113 done
114
115 # Send sigterm to make
116 kill "${PID}"
117
118 # Cleanup, to hopefully not interfere with future tests
119 apt-get purge -y gdb
120 apt-get autoremove -y
121 fi
122 done
123 wait "${PID}"
124 return "${?}"
125}
126
d0ffdf18
KS
127trap cleanup EXIT SIGINT SIGTERM
128
cf1271bb
JR
129lttng_version="$1"
130failed_tests=0
131
bb5dc121 132export LTTNG_ENABLE_DESTRUCTIVE_TESTS="will-break-my-system"
d0ffdf18 133timedatectl set-ntp false
bb5dc121 134
d0ffdf18
KS
135# When make check is interrupted, the default test driver
136# (`config/test-driver`) will still delete the log and trs
137# files for the currently running test.
046a1ad9 138test_timeout 90 make --keep-going check || failed_tests=1
bb5dc121
JR
139
140if [ -f "./tests/root_regression" ]; then
bf55e3f4 141 cd "./tests" || exit 1
d0ffdf18 142 prove --nocolor --verbose --merge --exec '' - < root_regression || failed_tests=2
bf55e3f4 143 cd ..
cf1271bb
JR
144fi
145
bf55e3f4
KS
146# This script doesn't exist in master anymore, but compatibility with old branches
147# should be retained until lttng-tools 2.13 is no longer supported
148if [ -f "./tests/root_destructive_tests" ]; then
149 cd "./tests" || exit 1
d0ffdf18 150 prove --nocolor --verbose --merge --exec '' - < root_destructive_tests || failed_tests=3
bf55e3f4
KS
151 cd ..
152else
153 echo 'root_destructive_tests not found'
154fi
cf1271bb 155
9ac936bc
KS
156if [[ "${failed_tests}" != "0" ]] ; then
157 find tests/ -iname '*.trs' -print0 -or -iname '*.log' -print0 | tar czf /tmp/coredump/logs.tgz --null -T -
158fi
159
bf55e3f4 160exit $failed_tests
This page took 0.031166 seconds and 4 git commands to generate.