2018-12-07 09:49:51 +01:00
#!/bin/bash
# Run this script from the root of the systemd's git repository
# or set REPO_ROOT to a correct path.
#
# Example execution on Fedora:
# dnf install docker
# systemctl start docker
# export CONT_NAME="my-fancy-container"
# travis-ci/managers/debian.sh SETUP RUN CLEANUP
2020-06-16 18:14:43 +02:00
PHASES = ( ${ @ :- SETUP RUN RUN_ASAN_UBSAN CLEANUP } )
2018-12-07 09:49:51 +01:00
DEBIAN_RELEASE = " ${ DEBIAN_RELEASE :- testing } "
2020-06-16 18:14:43 +02:00
CONT_NAME = " ${ CONT_NAME :- systemd -debian- $DEBIAN_RELEASE } "
2018-12-07 09:49:51 +01:00
DOCKER_EXEC = " ${ DOCKER_EXEC :- docker exec -it $CONT_NAME } "
DOCKER_RUN = " ${ DOCKER_RUN :- docker run } "
REPO_ROOT = " ${ REPO_ROOT :- $PWD } "
2020-06-16 18:49:37 +02:00
ADDITIONAL_DEPS = (
clang
fdisk
libfdisk-dev
libp11-kit-dev
libpwquality-dev
libssl-dev
libzstd-dev
perl
python3-libevdev
python3-pyparsing
zstd
)
2018-12-07 09:49:51 +01:00
function info( ) {
echo -e " \033[33;1m $1 \033[0m "
}
set -e
source " $( dirname $0 ) /travis_wait.bash "
for phase in " ${ PHASES [@] } " ; do
case $phase in
SETUP)
info "Setup phase"
info " Using Debian $DEBIAN_RELEASE "
2018-12-08 21:49:52 +01:00
printf " FROM debian: $DEBIAN_RELEASE \nRUN bash -c 'apt-get -y update && apt-get install -y systemd'\n " | docker build -t debian-with-systemd/latest -
2018-12-07 09:49:51 +01:00
info " Starting container $CONT_NAME "
2019-05-19 23:26:35 +02:00
$DOCKER_RUN -v $REPO_ROOT :/build:rw -e container = docker \
2018-12-07 09:49:51 +01:00
-w /build --privileged= true --name $CONT_NAME \
2019-03-05 05:44:11 +01:00
-dit --net= host debian-with-systemd/latest /bin/systemd
2018-12-07 09:49:51 +01:00
$DOCKER_EXEC bash -c " echo deb-src http://deb.debian.org/debian $DEBIAN_RELEASE main >>/etc/apt/sources.list "
2019-12-23 20:54:08 +01:00
# Wait for the container to properly boot up, otherwise we were
# running following apt-get commands during the initializing/starting
# (early/late bootup) phase, which caused nasty race conditions
$DOCKER_EXEC bash -c 'systemctl is-system-running --wait || :'
2018-12-07 09:49:51 +01:00
$DOCKER_EXEC apt-get -y update
$DOCKER_EXEC apt-get -y build-dep systemd
$DOCKER_EXEC apt-get -y install " ${ ADDITIONAL_DEPS [@] } "
; ;
2020-06-16 18:14:43 +02:00
RUN| RUN_GCC| RUN_CLANG)
2018-12-24 04:03:40 +01:00
if [ [ " $phase " = "RUN_CLANG" ] ] ; then
ENV_VARS = "-e CC=clang -e CXX=clang++"
2020-07-20 17:51:32 +02:00
MESON_ARGS = "--optimization=1"
2018-12-24 04:03:40 +01:00
fi
2020-07-20 17:51:32 +02:00
docker exec $ENV_VARS -it $CONT_NAME meson --werror -Dtests= unsafe -Dslow-tests= true -Dsplit-usr= true -Dman= true $MESON_ARGS build
2018-12-07 09:49:51 +01:00
$DOCKER_EXEC ninja -v -C build
2018-12-24 04:44:47 +01:00
docker exec -e " TRAVIS= $TRAVIS " -it $CONT_NAME ninja -C build test
2018-12-07 09:49:51 +01:00
; ;
2020-06-16 18:14:43 +02:00
RUN_ASAN_UBSAN| RUN_GCC_ASAN_UBSAN| RUN_CLANG_ASAN_UBSAN)
if [ [ " $phase " = "RUN_CLANG_ASAN_UBSAN" ] ] ; then
2018-12-07 09:49:51 +01:00
ENV_VARS = "-e CC=clang -e CXX=clang++"
2020-05-22 11:34:01 +02:00
# Build fuzzer regression tests only with clang (for now),
# see: https://github.com/systemd/systemd/pull/15886#issuecomment-632689604
# -Db_lundef=false: See https://github.com/mesonbuild/meson/issues/764
MESON_ARGS = "-Db_lundef=false -Dfuzz-tests=true --optimization=1"
2018-12-07 09:49:51 +01:00
fi
docker exec $ENV_VARS -it $CONT_NAME meson --werror -Dtests= unsafe -Db_sanitize= address,undefined -Dsplit-usr= true $MESON_ARGS build
$DOCKER_EXEC ninja -v -C build
# Never remove halt_on_error from UBSAN_OPTIONS. See https://github.com/systemd/systemd/commit/2614d83aa06592aedb.
travis_wait docker exec --interactive= false \
-e UBSAN_OPTIONS = print_stacktrace = 1:print_summary= 1:halt_on_error= 1 \
-e ASAN_OPTIONS = strict_string_checks = 1:detect_stack_use_after_return= 1:check_initialization_order= 1:strict_init_order= 1 \
-e " TRAVIS= $TRAVIS " \
-t $CONT_NAME \
meson test --timeout-multiplier= 3 -C ./build/ --print-errorlogs
; ;
CLEANUP)
info "Cleanup phase"
docker stop $CONT_NAME
docker rm -f $CONT_NAME
; ;
*)
echo >& 2 " Unknown phase ' $phase ' "
exit 1
esac
done