2020-07-01 15:56:42 +02:00
# Currently we have two build stages after our containers are built:
# - build (for traditional build and test or first stage build)
# - test (for test stages, using build artefacts from a build stage)
2020-07-01 15:56:32 +02:00
stages :
- containers
2020-07-01 15:56:33 +02:00
- containers-layer2
- containers-layer3
2020-07-01 15:56:32 +02:00
- build
2020-07-01 15:56:42 +02:00
- test
2020-07-01 15:56:32 +02:00
2020-07-01 15:56:47 +02:00
# We assume GitLab has it's own caching set up for RPM/APT repositories so we
# just take care of avocado assets here.
cache :
paths :
- $HOME/avocado/data/cache
2020-01-03 12:26:25 +01:00
include :
2020-05-20 09:45:58 +02:00
- local : '/.gitlab-ci.d/edk2.yml'
- local : '/.gitlab-ci.d/opensbi.yml'
2020-07-01 15:56:33 +02:00
- local : '/.gitlab-ci.d/containers.yml'
2020-07-31 08:38:23 +02:00
- local : '/.gitlab-ci.d/crossbuilds.yml'
2020-01-03 12:26:25 +01:00
2020-07-01 15:56:34 +02:00
.native_build_job_template : &native_build_job_definition
stage : build
image : $CI_REGISTRY_IMAGE/qemu/$IMAGE:latest
before_script :
- JOBS=$(expr $(nproc) + 1)
script :
- mkdir build
- cd build
- if test -n "$TARGETS";
then
../configure --enable-werror $CONFIGURE_ARGS --target-list="$TARGETS" ;
else
../configure --enable-werror $CONFIGURE_ARGS ;
fi
- make -j"$JOBS"
2020-07-01 15:56:42 +02:00
- if test -n "$MAKE_CHECK_ARGS";
then
2020-07-01 15:56:51 +02:00
make -j"$JOBS" $MAKE_CHECK_ARGS ;
2020-07-01 15:56:42 +02:00
fi
.native_test_job_template : &native_test_job_definition
stage : test
image : $CI_REGISTRY_IMAGE/qemu/$IMAGE:latest
script :
- cd build
- find . -type f -exec touch {} +
- make $MAKE_CHECK_ARGS
2020-07-30 10:35:48 +02:00
.acceptance_template : &acceptance_definition
cache :
key : "${CI_JOB_NAME}-cache"
paths :
- ${CI_PROJECT_DIR}/avocado-cache
policy : pull-push
before_script :
- mkdir -p ~/.config/avocado
- echo "[datadir.paths]" > ~/.config/avocado/avocado.conf
- echo "cache_dirs = ['${CI_PROJECT_DIR}/avocado-cache']"
>> ~/.config/avocado/avocado.conf
- if [ -d ${CI_PROJECT_DIR}/avocado-cache ]; then
du -chs ${CI_PROJECT_DIR}/avocado-cache ;
fi
2020-07-01 15:56:42 +02:00
after_script :
- cd build
- python3 -c 'import json; r = json.load(open("tests/results/latest/results.json")); [print(t["logfile"]) for t in r["tests"] if t["status"] not in ("PASS", "SKIP")]' | xargs cat
2020-07-30 10:35:48 +02:00
- du -chs ${CI_PROJECT_DIR}/avocado-cache
2019-02-13 12:54:41 +01:00
2020-07-14 17:35:45 +02:00
build-system-ubuntu :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : ubuntu2004
2020-07-14 17:35:45 +02:00
TARGETS : aarch64-softmmu alpha-softmmu cris-softmmu hppa-softmmu
moxie-softmmu microblazeel-softmmu mips64el-softmmu
2020-07-01 15:56:51 +02:00
MAKE_CHECK_ARGS : check-build
2020-07-01 15:56:42 +02:00
artifacts :
2020-08-05 23:10:44 +02:00
expire_in : 2 days
2020-07-01 15:56:42 +02:00
paths :
- build
2020-07-14 17:35:45 +02:00
check-system-ubuntu :
2020-07-01 15:56:42 +02:00
<< : *native_test_job_definition
needs :
2020-07-14 17:35:45 +02:00
- job : build-system-ubuntu
2020-07-01 15:56:42 +02:00
artifacts : true
variables :
IMAGE : ubuntu2004
2020-07-01 15:56:34 +02:00
MAKE_CHECK_ARGS : check
2019-02-13 12:54:41 +01:00
2020-07-14 17:35:45 +02:00
acceptance-system-ubuntu :
2020-07-01 15:56:42 +02:00
<< : *native_test_job_definition
needs :
2020-07-14 17:35:45 +02:00
- job : build-system-ubuntu
2020-07-01 15:56:42 +02:00
artifacts : true
variables :
IMAGE : ubuntu2004
MAKE_CHECK_ARGS : check-acceptance
2020-07-30 10:35:48 +02:00
<< : *acceptance_definition
2020-07-01 15:56:42 +02:00
2020-07-14 17:35:45 +02:00
build-system-debian :
<< : *native_build_job_definition
variables :
IMAGE : debian-amd64
TARGETS : arm-softmmu avr-softmmu i386-softmmu mipsel-softmmu
riscv64-softmmu sh4eb-softmmu sparc-softmmu xtensaeb-softmmu
MAKE_CHECK_ARGS : check-build
artifacts :
2020-08-05 23:10:44 +02:00
expire_in : 2 days
2020-07-14 17:35:45 +02:00
paths :
- build
check-system-debian :
<< : *native_test_job_definition
needs :
- job : build-system-debian
artifacts : true
variables :
IMAGE : debian-amd64
MAKE_CHECK_ARGS : check
acceptance-system-debian :
<< : *native_test_job_definition
needs :
- job : build-system-debian
artifacts : true
variables :
IMAGE : debian-amd64
MAKE_CHECK_ARGS : check-acceptance
2020-07-30 10:35:48 +02:00
<< : *acceptance_definition
2020-07-14 17:35:45 +02:00
build-system-fedora :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : fedora
2020-09-01 15:30:50 +02:00
CONFIGURE_ARGS : --disable-gcrypt --enable-nettle
2020-07-01 15:56:34 +02:00
TARGETS : tricore-softmmu unicore32-softmmu microblaze-softmmu mips-softmmu
2020-07-14 17:35:45 +02:00
xtensa-softmmu m68k-softmmu riscv32-softmmu ppc-softmmu sparc64-softmmu
2020-07-01 15:56:51 +02:00
MAKE_CHECK_ARGS : check-build
2020-07-01 15:56:42 +02:00
artifacts :
2020-08-05 23:10:44 +02:00
expire_in : 2 days
2020-07-01 15:56:42 +02:00
paths :
- build
2020-07-14 17:35:45 +02:00
check-system-fedora :
2020-07-01 15:56:42 +02:00
<< : *native_test_job_definition
needs :
2020-07-14 17:35:45 +02:00
- job : build-system-fedora
2020-07-01 15:56:42 +02:00
artifacts : true
variables :
IMAGE : fedora
2020-07-01 15:56:34 +02:00
MAKE_CHECK_ARGS : check
2019-02-13 12:54:41 +01:00
2020-07-14 17:35:45 +02:00
acceptance-system-fedora :
2020-07-01 15:56:42 +02:00
<< : *native_test_job_definition
needs :
2020-07-14 17:35:45 +02:00
- job : build-system-fedora
2020-07-01 15:56:42 +02:00
artifacts : true
variables :
IMAGE : fedora
MAKE_CHECK_ARGS : check-acceptance
2020-07-30 10:35:48 +02:00
<< : *acceptance_definition
2020-07-01 15:56:42 +02:00
2020-07-14 17:35:45 +02:00
build-system-centos :
<< : *native_build_job_definition
variables :
IMAGE : centos8
2020-09-01 15:30:50 +02:00
CONFIGURE_ARGS : --disable-nettle --enable-gcrypt
2020-07-14 17:35:45 +02:00
TARGETS : ppc64-softmmu lm32-softmmu or1k-softmmu s390x-softmmu
x86_64-softmmu rx-softmmu sh4-softmmu nios2-softmmu
MAKE_CHECK_ARGS : check-build
artifacts :
2020-08-05 23:10:44 +02:00
expire_in : 2 days
2020-07-14 17:35:45 +02:00
paths :
- build
check-system-centos :
<< : *native_test_job_definition
needs :
- job : build-system-centos
artifacts : true
variables :
IMAGE : centos8
MAKE_CHECK_ARGS : check
acceptance-system-centos :
<< : *native_test_job_definition
needs :
- job : build-system-centos
artifacts : true
variables :
IMAGE : centos8
MAKE_CHECK_ARGS : check-acceptance
2020-07-30 10:35:48 +02:00
<< : *acceptance_definition
2020-07-14 17:35:45 +02:00
2019-02-13 12:54:41 +01:00
build-disabled :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : fedora
2020-08-05 21:19:59 +02:00
CONFIGURE_ARGS : --disable-attr --disable-avx2 --disable-bochs
--disable-brlapi --disable-bzip2 --disable-cap-ng --disable-capstone
--disable-cloop --disable-coroutine-pool --disable-curl --disable-curses
--disable-dmg --disable-docs --disable-glusterfs --disable-gnutls
--disable-gtk --disable-guest-agent --disable-iconv --disable-kvm
--disable-libiscsi --disable-libpmem --disable-libssh --disable-libusb
--disable-libxml2 --disable-linux-aio --disable-live-block-migration
--disable-lzo --disable-malloc-trim --disable-mpath --disable-nettle
--disable-numa --disable-parallels --disable-pie --disable-qcow1
--disable-qed --disable-qom-cast-debug --disable-rbd --disable-rdma
--disable-replication --disable-sdl --disable-seccomp --disable-sheepdog
--disable-slirp --disable-smartcard --disable-snappy --disable-spice
--disable-strip --disable-tpm --disable-usb-redir --disable-vdi
--disable-vhost-crypto --disable-vhost-net --disable-vhost-scsi
--disable-vhost-user --disable-vhost-vdpa --disable-vhost-vsock
--disable-virglrenderer --disable-vnc --disable-vte --disable-vvfat
--disable-xen --disable-zstd
TARGETS : arm-softmmu i386-softmmu ppc64-softmmu mips64-softmmu
s390x-softmmu i386-linux-user
2020-07-01 15:56:34 +02:00
MAKE_CHECK_ARGS : check-qtest SPEED=slow
2019-02-13 12:54:41 +01:00
build-tcg-disabled :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : centos8
script :
- mkdir build
- cd build
- ../configure --disable-tcg --audio-drv-list=""
- make -j"$JOBS"
- make check-unit
- make check-qapi-schema
- cd tests/qemu-iotests/
- ./check -raw 001 002 003 004 005 008 009 010 011 012 021 025 032 033 048
gitlab-ci: Refresh the list of iotests
iotest 147 and 205 have recently been marked as "NBD-only", so they
are currently simply skipped and thus can be removed.
iotest 129 occasionally fails in the gitlab-CI, and according to Max,
there are some known issues with this test (see for example this URL:
https://lists.nongnu.org/archive/html/qemu-block/2019-06/msg00499.html ),
so for the time being, let's disable it until the problems are fixed.
The iotests 040, 127, 203 and 256 are scheduled to become part of "make
check-block", so we also do not have to test them seperately here anymore.
On the other side, new iotests have been added to the QEMU repository
in the past months, so we can now add some new test > 256 instead.
Message-Id: <20200121131936.8214-1-thuth@redhat.com>
Signed-off-by: Thomas Huth <thuth@redhat.com>
2020-01-20 14:33:32 +01:00
052 063 077 086 101 104 106 113 148 150 151 152 157 159 160 163
170 171 183 184 192 194 197 208 215 221 222 226 227 236 253 277
2020-07-01 15:56:34 +02:00
- ./check -qcow2 028 051 056 057 058 065 067 068 082 085 091 095 096 102 122
gitlab-ci: Refresh the list of iotests
iotest 147 and 205 have recently been marked as "NBD-only", so they
are currently simply skipped and thus can be removed.
iotest 129 occasionally fails in the gitlab-CI, and according to Max,
there are some known issues with this test (see for example this URL:
https://lists.nongnu.org/archive/html/qemu-block/2019-06/msg00499.html ),
so for the time being, let's disable it until the problems are fixed.
The iotests 040, 127, 203 and 256 are scheduled to become part of "make
check-block", so we also do not have to test them seperately here anymore.
On the other side, new iotests have been added to the QEMU repository
in the past months, so we can now add some new test > 256 instead.
Message-Id: <20200121131936.8214-1-thuth@redhat.com>
Signed-off-by: Thomas Huth <thuth@redhat.com>
2020-01-20 14:33:32 +01:00
124 132 139 142 144 145 151 152 155 157 165 194 196 197 200 202
208 209 215 216 218 222 227 234 246 247 248 250 254 255 257 258
260 261 262 263 264 270 272 273 277 279
2019-02-13 12:54:41 +01:00
build-user :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
2020-07-01 15:56:46 +02:00
IMAGE : debian-all-test-cross
CONFIGURE_ARGS : --disable-tools --disable-system
MAKE_CHECK_ARGS : check-tcg
2019-02-13 12:54:41 +01:00
build-clang :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : fedora
CONFIGURE_ARGS : --cc=clang --cxx=clang++
TARGETS : alpha-softmmu arm-softmmu m68k-softmmu mips64-softmmu
2020-07-15 06:32:48 +02:00
ppc-softmmu s390x-softmmu arm-linux-user
2020-07-01 15:56:34 +02:00
MAKE_CHECK_ARGS : check
2019-04-10 14:35:50 +02:00
2020-07-16 18:33:30 +02:00
build-oss-fuzz :
2020-07-15 06:32:48 +02:00
<< : *native_build_job_definition
variables :
IMAGE : fedora
script :
2020-07-16 18:33:30 +02:00
- mkdir build-oss-fuzz
- CC="clang" CXX="clang++" CFLAGS="-fsanitize=address"
./scripts/oss-fuzz/build.sh
2020-08-05 22:59:09 +02:00
- export ASAN_OPTIONS="fast_unwind_on_malloc=0"
2020-07-16 18:33:30 +02:00
- for fuzzer in $(find ./build-oss-fuzz/DEST_DIR/ -executable -type f
| grep -v slirp); do
grep "LLVMFuzzerTestOneInput" ${fuzzer} > /dev/null 2>&1 || continue ;
echo Testing ${fuzzer} ... ;
2020-08-05 22:59:09 +02:00
"${fuzzer}" -runs=1000 -seed=1 || exit 1 ;
2020-07-15 06:32:48 +02:00
done
2020-08-05 22:59:09 +02:00
# Unrelated to fuzzer: run some tests with -fsanitize=address
- cd build-oss-fuzz && make check-qtest-i386 check-unit
2020-07-15 06:32:48 +02:00
2019-04-10 14:35:50 +02:00
build-tci :
2020-07-01 15:56:34 +02:00
<< : *native_build_job_definition
variables :
IMAGE : fedora
script :
- TARGETS="aarch64 alpha arm hppa m68k microblaze moxie ppc64 s390x x86_64"
- mkdir build
- cd build
- ../configure --enable-tcg-interpreter
--target-list="$(for tg in $TARGETS; do echo -n ${tg}'-softmmu '; done)"
- make -j"$JOBS"
- make run-tcg-tests-x86_64-softmmu
- make tests/qtest/boot-serial-test tests/qtest/cdrom-test tests/qtest/pxe-test
- for tg in $TARGETS ; do
2020-08-03 17:04:25 +02:00
export QTEST_QEMU_BINARY="./qemu-system-${tg}" ;
2020-07-01 15:56:34 +02:00
./tests/qtest/boot-serial-test || exit 1 ;
./tests/qtest/cdrom-test || exit 1 ;
done
2020-08-03 17:04:25 +02:00
- QTEST_QEMU_BINARY="./qemu-system-x86_64" ./tests/qtest/pxe-test
- QTEST_QEMU_BINARY="./qemu-system-s390x" ./tests/qtest/pxe-test -m slow
2020-09-01 15:30:50 +02:00
# Most jobs test latest gcrypt or nettle builds
#
# These jobs test old gcrypt and nettle from RHEL7
# which had some API differences.
build-crypto-old-nettle :
<< : *native_build_job_definition
variables :
IMAGE : centos7
TARGETS : x86_64-softmmu x86_64-linux-user
CONFIGURE_ARGS : --disable-gcrypt --enable-nettle
MAKE_CHECK_ARGS : check-build
artifacts :
paths :
- build
check-crypto-old-nettle :
<< : *native_test_job_definition
needs :
- job : build-crypto-old-nettle
artifacts : true
variables :
IMAGE : centos7
MAKE_CHECK_ARGS : check
build-crypto-old-gcrypt :
<< : *native_build_job_definition
variables :
IMAGE : centos7
TARGETS : x86_64-softmmu x86_64-linux-user
CONFIGURE_ARGS : --disable-nettle --enable-gcrypt
MAKE_CHECK_ARGS : check-build
artifacts :
paths :
- build
check-crypto-old-gcrypt :
<< : *native_test_job_definition
needs :
- job : build-crypto-old-gcrypt
artifacts : true
variables :
IMAGE : centos7
MAKE_CHECK_ARGS : check
build-crypto-only-gnutls :
<< : *native_build_job_definition
variables :
IMAGE : centos7
TARGETS : x86_64-softmmu x86_64-linux-user
CONFIGURE_ARGS : --disable-nettle --disable-gcrypt --enable-gnutls
MAKE_CHECK_ARGS : check-build
artifacts :
paths :
- build
check-crypto-only-gnutls :
<< : *native_test_job_definition
needs :
- job : build-crypto-only-gnutls
artifacts : true
variables :
IMAGE : centos7
MAKE_CHECK_ARGS : check