diff options
author | Michel Dänzer <michel.daenzer@amd.com> | 2018-12-11 11:47:16 +0100 |
---|---|---|
committer | Michel Dänzer <michel@daenzer.net> | 2018-12-11 11:47:16 +0100 |
commit | be862ed459b06ab7dfc80b5c3d1e2ac7e9327a6e (patch) | |
tree | e1f29f1209be243bfb0e14b135e6ff69ccad3f3d | |
parent | b11ee02c4596ddee3c9ff2141be5c91815efacc3 (diff) |
Generate docker image as part of CI pipeline
This removes the dependency on an externally generated docker image, and
should make it easier to update the docker image or make other changes
related to it.
v2:
* If the image doesn't exist, try pulling it from the main repo's
registry.
* Use debian:testing-slim as the base, might result in a slightly
smaller image.
v3:
* Prevent installation of packages which are only recommended, for an
even smaller image.
* Add recommendation to remove new image from source repository in
favour of the main repository's.
Acked-by: Alex Deucher <alexander.deucher@amd.com> # v2
-rw-r--r-- | .gitlab-ci.yml | 39 | ||||
-rw-r--r-- | .gitlab-ci/Dockerfile | 64 |
2 files changed, 101 insertions, 2 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index aac8bb7..d1960fb 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,8 +1,43 @@ -image: registry.freedesktop.org/xorg/driver/xf86-video-amdgpu:debian-testing-20181003 +# IMAGE_TAG is the tag of the docker image used for the build jobs. If the +# image doesn't exist yet, the docker-image stage generates it. +# +# In order to generate a new image, one should generally change the tag. +# While removing the image from the registry would also work, that's not +# recommended except for ephemeral images during development: Replacing an +# image after a significant amount of time might pull in newer versions of +# gcc/clang or other packages, which might break the build with older commits +# using the same tag. +# +# After merging a change resulting in generating a new image to the main +# repository, it's recommended to remove the image from the source repository's +# container registry, so that the image from the main repository's registry +# will be used there as well. +variables: + IMAGE_TAG: "debian-testing-20181213" + IMAGE_LOCAL: "$CI_REGISTRY_IMAGE:$IMAGE_TAG" + IMAGE_MAIN: "registry.freedesktop.org/xorg/driver/$CI_PROJECT_NAME:$IMAGE_TAG" stages: + - docker-image - build + +debian-testing: + stage: docker-image + image: docker:stable + services: + - docker:dind + before_script: + - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY + script: + - docker pull "$IMAGE_LOCAL" || + ((docker pull "$IMAGE_MAIN" && docker tag "$IMAGE_MAIN" "$IMAGE_LOCAL") || + docker build -t "$IMAGE_LOCAL" .gitlab-ci; + docker push "$IMAGE_LOCAL") + + +image: $IMAGE_LOCAL + # The default build instructions .default_build: stage: build @@ -44,7 +79,7 @@ xserver-1.14: XSERVER_VERSION: "1.14" xserver-1.15: - extends: .default_build + extends: xserver-1.14 variables: XSERVER_VERSION: "1.15" diff --git a/.gitlab-ci/Dockerfile b/.gitlab-ci/Dockerfile new file mode 100644 index 0000000..161edb5 --- /dev/null +++ b/.gitlab-ci/Dockerfile @@ -0,0 +1,64 @@ +FROM debian:testing-slim + +WORKDIR /tmp + +RUN export DEBIAN_FRONTEND=noninteractive; \ + echo 'path-exclude=/usr/share/doc/*' > /etc/dpkg/dpkg.cfg.d/99-exclude-cruft && \ + echo 'path-exclude=/usr/share/locale/*' >> /etc/dpkg/dpkg.cfg.d/99-exclude-cruft && \ + echo 'path-exclude=/usr/share/man/*' >> /etc/dpkg/dpkg.cfg.d/99-exclude-cruft && \ + echo 'APT::Get::Build-Dep-Automatic "true";' > /etc/apt/apt.conf && \ + echo 'APT::Install-Recommends "false";' >> /etc/apt/apt.conf && \ + echo '#!/bin/sh' > /usr/sbin/policy-rc.d && \ + echo 'exit 101' >> /usr/sbin/policy-rc.d && \ + chmod +x /usr/sbin/policy-rc.d && \ + echo 'deb-src https://deb.debian.org/debian testing main' >/etc/apt/sources.list.d/deb-src.list && \ + apt-get update && \ + apt-get install -y git ca-certificates build-essential automake autoconf libtool pkg-config && \ + apt-get build-dep -y xorg-server && \ + \ + git clone https://gitlab.freedesktop.org/xorg/lib/libXfont.git && \ + cd libXfont && \ + git checkout libXfont-1.5-branch && \ + ./autogen.sh && \ + make install-pkgconfigDATA && \ + cd .. && rm -rf libXfont && \ + git clone https://gitlab.freedesktop.org/xorg/xserver.git && \ + cd xserver && \ + git checkout server-1.13-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.13 --enable-dri2 && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.14-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.14 --enable-dri2 && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.15-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.15 --enable-dri2 && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.16-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.16 --enable-dri2 --enable-dri3 --enable-glamor && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.17-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.17 --enable-dri2 --enable-dri3 --enable-glamor && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.18-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.18 --enable-dri2 --enable-dri3 --enable-glamor && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.19-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.19 --enable-dri2 --enable-dri3 --enable-glamor && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + git checkout server-1.20-branch && \ + ./autogen.sh --prefix=/usr/local/xserver-1.20 --enable-dri2 --enable-dri3 --enable-glamor && \ + make -C include install-nodist_sdkHEADERS && \ + make install-headers install-aclocalDATA install-pkgconfigDATA clean && \ + cd .. && rm -rf xserver && \ + \ + apt-get install -y clang xutils-dev libdrm-dev libgl1-mesa-dev libgbm-dev libudev-dev \ + x11proto-dev libpixman-1-dev libpciaccess-dev && \ + apt-get purge -y git ca-certificates && apt-get autoremove -y --purge && \ + apt-get clean && rm -f /var/lib/apt/lists/deb.debian.org_debian_dists_testing_* |