packaging: Use dev_wos macro to configure the SMACK feature on build time
[platform/upstream/systemd.git] / .travis.yml
1 sudo: required
2 dist: xenial
3 services:
4     - docker
5
6 env:
7     global:
8         - AUTHOR_EMAIL="$(git log -1 $TRAVIS_COMMIT --pretty=\"%aE\")"
9         - CI_MANAGERS="$TRAVIS_BUILD_DIR/travis-ci/managers"
10         - CI_TOOLS="$TRAVIS_BUILD_DIR/travis-ci/tools"
11         - REPO_ROOT="$TRAVIS_BUILD_DIR"
12
13 stages:
14     - name: Build & test
15       if: type != cron
16
17     - name: Fuzzit-Fuzzing
18       if: type = cron
19
20     - name: Fuzzit-Regression
21       if: type != cron
22
23     # Run Coverity periodically instead of for each commit/PR
24     - name: Coverity
25       if: type = cron
26
27 jobs:
28     include:
29         - stage: Build & test
30           name: Debian Testing
31           language: bash
32           env:
33               - DEBIAN_RELEASE="testing"
34               - CONT_NAME="systemd-debian-$DEBIAN_RELEASE"
35               - DOCKER_EXEC="docker exec -ti $CONT_NAME"
36           before_install:
37               - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce
38               - docker --version
39           install:
40               - $CI_MANAGERS/debian.sh SETUP
41           script:
42               - set -e
43               # Build systemd
44               - $CI_MANAGERS/debian.sh RUN
45               - set +e
46           after_script:
47               - $CI_MANAGERS/debian.sh CLEANUP
48
49         - name: Debian Testing (ASan+UBSan)
50           language: bash
51           env:
52               - DEBIAN_RELEASE="testing"
53               - CONT_NAME="systemd-debian-$DEBIAN_RELEASE"
54               - DOCKER_EXEC="docker exec -ti $CONT_NAME"
55           before_install:
56               - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce
57               - docker --version
58           install:
59               - $CI_MANAGERS/debian.sh SETUP
60           script:
61               - set -e
62               - $CI_MANAGERS/debian.sh RUN_ASAN
63               - set +e
64           after_script:
65               - $CI_MANAGERS/debian.sh CLEANUP
66
67         - name: Debian Testing (clang)
68           language: bash
69           env:
70               - DEBIAN_RELEASE="testing"
71               - CONT_NAME="systemd-debian-$DEBIAN_RELEASE"
72               - DOCKER_EXEC="docker exec -ti $CONT_NAME"
73           before_install:
74               - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce
75               - docker --version
76           install:
77               - $CI_MANAGERS/debian.sh SETUP
78           script:
79               - set -e
80               - $CI_MANAGERS/debian.sh RUN_CLANG
81               - set +e
82           after_script:
83               - $CI_MANAGERS/debian.sh CLEANUP
84
85         - name: Debian Testing (clang ASan+UBSan)
86           language: bash
87           env:
88               - DEBIAN_RELEASE="testing"
89               - CONT_NAME="systemd-debian-$DEBIAN_RELEASE"
90               - DOCKER_EXEC="docker exec -ti $CONT_NAME"
91           before_install:
92               - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce
93               - docker --version
94           install:
95               - $CI_MANAGERS/debian.sh SETUP
96           script:
97               - set -e
98               - $CI_MANAGERS/debian.sh RUN_CLANG_ASAN
99               - set +e
100           after_script:
101               - $CI_MANAGERS/debian.sh CLEANUP
102
103         - stage: Fuzzit-Regression
104           name:  Continuous Fuzzing via Fuzzit (regression)
105           language: bash
106           script:
107             - set -e
108             - $CI_MANAGERS/fuzzit.sh regression
109             - set +e
110
111         - stage: Fuzzit-Fuzzing
112           name: Continuous Fuzzing via Fuzzit (fuzzing daily)
113           language: bash
114           script:
115             - set -e
116             - $CI_MANAGERS/fuzzit.sh fuzzing
117             - set +e
118
119         - stage: Coverity
120           language: bash
121           env:
122               - FEDORA_RELEASE="latest"
123               - CONT_NAME="coverity-fedora-$FEDORA_RELEASE"
124               - DOCKER_EXEC="docker exec -ti $CONT_NAME"
125               - TOOL_BASE="/var/tmp/coverity-scan-analysis"
126               - DOCKER_RUN="docker run -v $TOOL_BASE:$TOOL_BASE:rw --env-file .cov-env"
127               # Coverity env variables
128               - PLATFORM="$(uname)"
129               - TOOL_ARCHIVE="/var/tmp/cov-analysis-$PLATFORM.tgz"
130               - SCAN_URL="https://scan.coverity.com"
131               - UPLOAD_URL="https://scan.coverity.com/builds"
132               - COVERITY_SCAN_PROJECT_NAME="$TRAVIS_REPO_SLUG"
133               - COVERITY_SCAN_NOTIFICATION_EMAIL="${AUTHOR_EMAIL}"
134               - COVERITY_SCAN_BRANCH_PATTERN="$TRAVIS_BRANCH"
135               # Encrypted COVERITY_SCAN_TOKEN env variable
136               # Generated using `travis encrypt -r systemd/systemd COVERITY_SCAN_TOKEN=xxxx`
137               - secure: "jKSz+Y1Mv8xMpQHh7g5lzW7E6HQGndFz/vKDJQ1CVShwFoyjV3Zu+MFS3UYKlh1236zL0Z4dvsYFx/b3Hq8nxZWCrWeZs2NdXgy/wh8LZhxwzcGYigp3sIA/cYdP5rDjFJO0MasNkl25/rml8+eZWz+8/xQic98UQHjSco/EOWtssoRcg0J0c4eDM7bGLfIQWE73NNY1Q1UtWjKmx1kekVrM8dPmHXJ9aERka7bmcbJAcKd6vabs6DQ5AfWccUPIn/EsRYqIJTRxJrFYU6XizANZ1a7Vwk/DWHZUEn2msxcZw5BbAMDTMx0TbfrNkKSHMHuvQUCu6KCBAq414i+LgkMfmQ2SWwKiIUsud1kxXX3ZPl9bxDv1HkvVdcniC/EM7lNEEVwm4meOnjuhI2lhOyOjmP3FTSlMHGP7xlK8DS2k9fqL58vn0BaSjwWgd+2+HuL2+nJmxcK1eLGzKqaostFxrk2Xs2vPZkUdV2nWY/asUrcWHml6YlWDn2eP83pfwxHYsMiEHY/rTKvxeVY+iirO/AphoO+eaYu7LvjKZU1Yx5Z4u/SnGWAiCH0yhMis0bWmgi7SCbw+sDd2uya+aoiLIGiB2ChW7hXHXCue/dif6/gLU7b+L8R00pQwnWdvKUPoIJCmZJYCluTeib4jpW+EmARB2+nR8wms2K9FGKM="
138           before_install:
139               - sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce
140               - docker --version
141           install:
142               # Install Coverity on the host
143               - $CI_TOOLS/get-coverity.sh
144               # Export necessary env variables for Coverity
145               - env | grep -E "TRAVIS|COV|TOOL|URL" > .cov-env
146               # Pull a Docker image and start a new container
147               - $CI_MANAGERS/fedora.sh SETUP
148           script:
149               - set -e
150               # Preconfigure with meson to prevent Coverity from capturing meson metadata
151               - $DOCKER_EXEC meson cov-build -Dman=false
152               # Run Coverity
153               - $DOCKER_EXEC tools/coverity.sh build
154               - $DOCKER_EXEC tools/coverity.sh upload
155
156               - set +e
157           after_script:
158               - $CI_MANAGERS/fedora.sh CLEANUP