# repository's registry will be used there as well.
variables:
UPSTREAM_REPO: mesa/mesa
- DEBIAN_TAG: "2019-08-08"
+ DEBIAN_TAG: "2019-08-09"
DEBIAN_VERSION: stretch-slim
DEBIAN_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_VERSION:$DEBIAN_TAG"
stages:
- containers-build
- build+test
+ - test
# When to automatically run the CI
when:
- runner_system_failure
+.ci-deqp-artifacts: &ci-deqp-artifacts
+ artifacts:
+ when: always
+ untracked: false
+ paths:
+ # Watch out! Artifacts are relative to the build dir.
+ # https://gitlab.com/gitlab-org/gitlab-ce/commit/8788fb925706cad594adf6917a6c5f6587dd1521
+ - artifacts
# CONTAINERS
- ccache --zero-stats || true
- ccache --show-stats || true
after_script:
+ # In case the install dir is being saved as artifacts, tar it up
+ # so that symlinks and hardlinks aren't each packed separately in
+ # the zip file.
+ - if [ -d install ]; then
+ tar -cf artifacts/install.tar install;
+ fi
- export CCACHE_DIR="$PWD/ccache"
- ccache --show-stats
-D osmesa=gallium
-D tools=all
MESON_SHADERDB: "true"
+ BUILDTYPE: "debugoptimized"
+ <<: *ci-deqp-artifacts
meson-clover:
extends: .meson-build
-D gallium-xa=false
-D gallium-nine=false
-D llvm=false
+ <<: *ci-deqp-artifacts
script:
- .gitlab-ci/meson-build.sh
LLVM_VERSION: "3.4"
# LLVM 3.4 packages were built with an old libstdc++ ABI
CXX: "g++ -D_GLIBCXX_USE_CXX11_ABI=0"
+
+.deqp-test:
+ <<: *ci-run-policy
+ stage: test
+ image: $DEBIAN_IMAGE
+ variables:
+ GIT_STRATEGY: none # testing doesn't build anything from source
+ DEQP_SKIPS: deqp-default-skips.txt
+ script:
+ # Note: Build dir (and thus install) may be dirty due to GIT_STRATEGY
+ - rm -rf install
+ - tar -xf artifacts/install.tar
+ - ./artifacts/deqp-runner.sh
+ artifacts:
+ when: on_failure
+ name: "$CI_JOB_NAME-$CI_COMMIT_REF_NAME"
+ paths:
+ - results/
+
+test-llvmpipe-gles2:
+ parallel: 4
+ variables:
+ DEQP_VER: gles2
+ DEQP_EXPECTED_FAILS: deqp-llvmpipe-fails.txt
+ LIBGL_ALWAYS_SOFTWARE: "true"
+ DEQP_RENDERER_MATCH: "llvmpipe"
+ extends: .deqp-test
+ dependencies:
+ - meson-main
+
+test-softpipe-gles2:
+ parallel: 4
+ variables:
+ DEQP_VER: gles2
+ DEQP_EXPECTED_FAILS: deqp-softpipe-fails.txt
+ LIBGL_ALWAYS_SOFTWARE: "true"
+ DEQP_RENDERER_MATCH: "softpipe"
+ GALLIUM_DRIVER: "softpipe"
+ extends: .deqp-test
+ dependencies:
+ - meson-main
+
+# The GLES2 CTS run takes about 8 minutes of CPU time, while GLES3 is
+# 25 minutes. Until we can get its runtime down, just do a partial
+# (every 10 tests) run.
+test-softpipe-gles3-limited:
+ variables:
+ DEQP_VER: gles3
+ DEQP_EXPECTED_FAILS: deqp-softpipe-fails.txt
+ LIBGL_ALWAYS_SOFTWARE: "true"
+ DEQP_RENDERER_MATCH: "softpipe"
+ GALLIUM_DRIVER: "softpipe"
+ CI_NODE_INDEX: 1
+ CI_NODE_TOTAL: 10
+ extends: .deqp-test
+ dependencies:
+ - meson-main