]> git.ipfire.org Git - thirdparty/systemd.git/blame - travis-ci/managers/fedora.sh
coverity: replace python with jq
[thirdparty/systemd.git] / travis-ci / managers / fedora.sh
CommitLineData
a9145fc4
FS
1#!/bin/bash
2
3# Run this script from the root of the systemd's git repository
4# or set REPO_ROOT to a correct path.
5#
6# Example execution on Fedora:
0d589dfc 7# dnf install docker
a9145fc4
FS
8# systemctl start docker
9# export CONT_NAME="my-fancy-container"
10# travis-ci/managers/fedora.sh SETUP RUN CLEANUP
11
79f6178e 12PHASES=(${@:-SETUP RUN RUN_ASAN CLEANUP})
a9145fc4
FS
13FEDORA_RELEASE="${FEDORA_RELEASE:-rawhide}"
14CONT_NAME="${CONT_NAME:-fedora-$FEDORA_RELEASE-$RANDOM}"
15DOCKER_EXEC="${DOCKER_EXEC:-docker exec -it $CONT_NAME}"
16DOCKER_RUN="${DOCKER_RUN:-docker run}"
17REPO_ROOT="${REPO_ROOT:-$PWD}"
9fd1a0ba 18ADDITIONAL_DEPS=(dnf-plugins-core
738606e4 19 jq iputils
9fd1a0ba
ZJS
20 hostname libasan
21 python3-pyparsing
22 python3-evdev
23 libubsan
24 clang
25 llvm
26 perl)
a9145fc4
FS
27
28function info() {
29 echo -e "\033[33;1m$1\033[0m"
30}
31
32set -e
33
d419b75c
EV
34source "$(dirname $0)/travis_wait.bash"
35
a9145fc4
FS
36for phase in "${PHASES[@]}"; do
37 case $phase in
38 SETUP)
39 info "Setup phase"
40 info "Using Fedora $FEDORA_RELEASE"
a9145fc4
FS
41 # Pull a Docker image and start a new container
42 docker pull fedora:$FEDORA_RELEASE
43 info "Starting container $CONT_NAME"
44 $DOCKER_RUN -v $REPO_ROOT:/build:rw \
a9145fc4
FS
45 -w /build --privileged=true --name $CONT_NAME \
46 -dit --net=host fedora:$FEDORA_RELEASE /sbin/init
532a92fb
FS
47 # Beautiful workaround for Fedora's version of Docker
48 sleep 1
a9145fc4
FS
49 $DOCKER_EXEC dnf makecache
50 # Install necessary build/test requirements
532a92fb 51 $DOCKER_EXEC dnf -y --exclude selinux-policy\* upgrade
a9145fc4
FS
52 $DOCKER_EXEC dnf -y install "${ADDITIONAL_DEPS[@]}"
53 $DOCKER_EXEC dnf -y builddep systemd
54 ;;
55 RUN)
56 info "Run phase"
57 # Build systemd
7970a525 58 $DOCKER_EXEC meson --werror -Dtests=unsafe -Dslow-tests=true build
eeec5f2a 59 $DOCKER_EXEC ninja -v -C build
1667d63a 60 $DOCKER_EXEC ninja -C build test
79f6178e 61 ;;
37cbcd46 62 RUN_CLANG)
0b0673b6 63 docker exec -e CC=clang -e CXX=clang++ -it $CONT_NAME meson --werror -Dtests=unsafe -Dslow-tests=true -Dman=true build
37cbcd46
EV
64 $DOCKER_EXEC ninja -v -C build
65 $DOCKER_EXEC ninja -C build test
66 ;;
b8366c54
EV
67 RUN_ASAN|RUN_CLANG_ASAN)
68 if [[ "$phase" = "RUN_CLANG_ASAN" ]]; then
69 ENV_VARS="-e CC=clang -e CXX=clang++"
70 MESON_ARGS="-Db_lundef=false" # See https://github.com/mesonbuild/meson/issues/764
71 fi
72 docker exec $ENV_VARS -it $CONT_NAME meson --werror -Dtests=unsafe -Db_sanitize=address,undefined $MESON_ARGS build
1667d63a 73 $DOCKER_EXEC ninja -v -C build
6dfe7f43
EV
74
75 # Never remove halt_on_error from UBSAN_OPTIONS. See https://github.com/systemd/systemd/commit/2614d83aa06592aedb.
b6b35f0e
EV
76 travis_wait docker exec --interactive=false \
77 -e UBSAN_OPTIONS=print_stacktrace=1:print_summary=1:halt_on_error=1 \
78 -e ASAN_OPTIONS=strict_string_checks=1:detect_stack_use_after_return=1:check_initialization_order=1:strict_init_order=1 \
f5f9a580 79 -e "TRAVIS=$TRAVIS" \
b6b35f0e
EV
80 -t $CONT_NAME \
81 meson test --timeout-multiplier=3 -C ./build/ --print-errorlogs
a9145fc4
FS
82 ;;
83 CLEANUP)
84 info "Cleanup phase"
85 docker stop $CONT_NAME
86 docker rm -f $CONT_NAME
87 ;;
88 *)
89 echo >&2 "Unknown phase '$phase'"
90 exit 1
91 esac
92done