summaryrefslogtreecommitdiffstats
path: root/taskcluster/docker/debian-build/Dockerfile
diff options
context:
space:
mode:
Diffstat (limited to 'taskcluster/docker/debian-build/Dockerfile')
-rw-r--r--taskcluster/docker/debian-build/Dockerfile94
1 files changed, 94 insertions, 0 deletions
diff --git a/taskcluster/docker/debian-build/Dockerfile b/taskcluster/docker/debian-build/Dockerfile
new file mode 100644
index 0000000000..29c6280765
--- /dev/null
+++ b/taskcluster/docker/debian-build/Dockerfile
@@ -0,0 +1,94 @@
+FROM $DOCKER_IMAGE_PARENT
+MAINTAINER Mike Hommey <mhommey@mozilla.com>
+
+VOLUME /builds/worker/checkouts
+VOLUME /builds/worker/workspace
+VOLUME /builds/worker/tooltool-cache
+
+ENV XZ_OPT=-T0
+
+ARG TASKCLUSTER_ROOT_URL
+ARG DOCKER_IMAGE_PACKAGES
+RUN /usr/local/sbin/setup_packages.sh $TASKCLUSTER_ROOT_URL $DOCKER_IMAGE_PACKAGES
+
+# %ARG ARCH
+RUN dpkg --add-architecture $ARCH
+
+# Ideally, we wouldn't need gcc-multilib and the extra linux-libc-dev,
+# but the latter is required to make the former installable, and the former
+# because of bug 1409276.
+# We exclude /usr/share/doc/*/changelog.Debian* files because they might differ
+# between i386 and amd64 variants of the packages we build on automation
+# because of dates stored in them by debchange (and both might end up installed
+# in some cases).
+# On Debian 7, pkg-config was not multiarch-aware, so we rely on the $ARCH
+# pkg-config being valid on the host. On more recent versions of Debian, we can
+# use pkg-config, which is multiarch-aware, but we also need dpkg-dev because
+# of https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=916772.
+#
+# We also need libstdc++ development files, but the exact version of libstdc++
+# that we need varies between debian versions.
+RUN apt-get update && \
+ apt-get dist-upgrade && \
+ echo path-exclude=/usr/share/doc/*/changelog.Debian* > /etc/dpkg/dpkg.cfg.d/excludes && \
+ if grep -q ^8\\. /etc/debian_version; then \
+ PKG_CONFIG=pkg-config:$ARCH; \
+ else \
+ PKG_CONFIG="pkg-config dpkg-dev"; \
+ fi && \
+ if grep -q ^8\\. /etc/debian_version; then \
+ LIBSTDCXX=libstdc++-4.9-dev; \
+ elif grep -q ^9\\. /etc/debian_version; then \
+ LIBSTDCXX=libstdc++-6-dev; \
+ elif grep -q ^10\\. /etc/debian_version; then \
+ libstdcxx=libstdc++-8-dev; \
+ LIBSTDCXX="$libstdcxx $libstdcxx:$ARCH"; \
+ fi && \
+ apt-get install \
+ autoconf2.13 \
+ automake \
+ bzip2 \
+ curl \
+ file \
+ gawk \
+ gcc-multilib \
+ gnupg \
+ jq \
+ libucl1 \
+ p7zip-full \
+ procps \
+ python-dev \
+ python-pip \
+ python-setuptools \
+ python-virtualenv \
+ python3-dev \
+ rsync \
+ screen \
+ tar \
+ unzip \
+ uuid \
+ valgrind \
+ wget \
+ x11-utils \
+ xvfb \
+ yasm \
+ zip \
+ linux-libc-dev \
+ linux-libc-dev:$ARCH \
+ $PKG_CONFIG \
+ $LIBSTDCXX \
+ libdbus-glib-1-dev:$ARCH \
+ libdrm-dev:$ARCH \
+ libfontconfig1-dev:$ARCH \
+ libfreetype6-dev:$ARCH \
+ libgconf2-dev:$ARCH \
+ libgtk-3-dev:$ARCH \
+ libgtk2.0-dev:$ARCH \
+ libpango1.0-dev:$ARCH \
+ libpulse-dev:$ARCH \
+ libx11-xcb-dev:$ARCH \
+ libxt-dev:$ARCH
+
+# Add wrapper scripts for xvfb allowing tasks to easily retry starting up xvfb
+# %include taskcluster/docker/recipes/xvfb.sh
+COPY topsrcdir/taskcluster/docker/recipes/xvfb.sh /builds/worker/scripts/xvfb.sh