1#===----------------------------------------------------------------------===## 2# 3# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4# See https://llvm.org/LICENSE.txt for license information. 5# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6# 7#===----------------------------------------------------------------------===## 8 9# 10# This Dockerfile describes the base image used to run the various libc++ 11# build bots. By default, the image runs the Buildkite Agent, however one 12# can also just start the image with a shell to debug CI failures. 13# 14# To start a Buildkite Agent, run it as: 15# $ docker run --env-file <secrets> -it $(docker build -q libcxx/utils/ci) 16# 17# The environment variables in `<secrets>` should be the ones necessary 18# to run a BuildKite agent. 19# 20# If you're only looking to run the Docker image locally for debugging a 21# build bot, see the `run-buildbot-container` script located in this directory. 22# 23# A pre-built version of this image is maintained on DockerHub as ldionne/libcxx-builder. 24# To update the image, rebuild it and push it to ldionne/libcxx-builder (which 25# will obviously only work if you have permission to do so). 26# 27# $ docker build -t ldionne/libcxx-builder libcxx/utils/ci 28# $ docker push ldionne/libcxx-builder 29# 30 31FROM ubuntu:jammy 32 33# Make sure apt-get doesn't try to prompt for stuff like our time zone, etc. 34ENV DEBIAN_FRONTEND=noninteractive 35 36RUN apt-get update && apt-get install -y bash curl 37 38# Install various tools used by the build or the test suite 39RUN apt-get update && apt-get install -y ninja-build python3 python3-sphinx python3-distutils python3-psutil git gdb 40 41# Locales for gdb and localization tests 42RUN apt-get update && apt-get install -y language-pack-en language-pack-fr \ 43 language-pack-ja language-pack-ru \ 44 language-pack-zh-hans 45# These two are not enabled by default so generate them 46RUN printf "fr_CA ISO-8859-1\ncs_CZ ISO-8859-2" >> /etc/locale.gen 47RUN mkdir /usr/local/share/i1en/ 48RUN printf "fr_CA ISO-8859-1\ncs_CZ ISO-8859-2" >> /usr/local/share/i1en/SUPPORTED 49RUN locale-gen 50 51# Install Clang <latest>, <latest-1> and ToT, which are the ones we support. 52# We also install <latest-2> because we need to support the "latest-1" of the 53# current LLVM release branch, which is effectively the <latest-2> of the 54# tip-of-trunk LLVM. For example, after branching LLVM 14 but before branching 55# LLVM 15, we still need to have Clang 12 in this Docker image because the LLVM 56# 14 release branch CI uses it. The tip-of-trunk CI will never use Clang 12, 57# though. 58ENV LLVM_LATEST_VERSION=14 59RUN apt-get update && apt-get install -y lsb-release wget software-properties-common 60RUN wget https://apt.llvm.org/llvm.sh -O /tmp/llvm.sh 61# TODO Use the apt.llvm.org version after branching to LLVM 15 62RUN apt-get update && apt-get install -y clang-$(($LLVM_LATEST_VERSION - 2)) 63#RUN bash /tmp/llvm.sh $(($LLVM_LATEST_VERSION - 2)) # for CI transitions 64RUN bash /tmp/llvm.sh $(($LLVM_LATEST_VERSION - 1)) # previous release 65RUN bash /tmp/llvm.sh $LLVM_LATEST_VERSION # latest release 66RUN bash /tmp/llvm.sh $(($LLVM_LATEST_VERSION + 1)) # current ToT 67 68# Make the latest version of Clang the "default" compiler on the system 69# TODO: In the future, all jobs should be using an explicitly-versioned version of Clang instead, 70# and we can get rid of this entirely. 71RUN ln -fs /usr/bin/clang++-$LLVM_LATEST_VERSION /usr/bin/c++ && [ -e $(readlink /usr/bin/c++) ] 72RUN ln -fs /usr/bin/clang-$LLVM_LATEST_VERSION /usr/bin/cc && [ -e $(readlink /usr/bin/cc) ] 73 74# Install clang-format 75RUN apt-get install -y clang-format-$LLVM_LATEST_VERSION 76RUN ln -s /usr/bin/clang-format-$LLVM_LATEST_VERSION /usr/bin/clang-format && [ -e $(readlink /usr/bin/clang-format) ] 77RUN ln -s /usr/bin/git-clang-format-$LLVM_LATEST_VERSION /usr/bin/git-clang-format && [ -e $(readlink /usr/bin/git-clang-format) ] 78 79# Install clang-tidy 80RUN apt-get install -y clang-tidy-$LLVM_LATEST_VERSION 81RUN ln -s /usr/bin/clang-tidy-$LLVM_LATEST_VERSION /usr/bin/clang-tidy && [ -e $(readlink /usr/bin/clang-tidy) ] 82 83# Install the most recent GCC, like clang install the previous version as a transition. 84ENV GCC_LATEST_VERSION=12 85RUN apt-get update && apt install -y gcc-$((GCC_LATEST_VERSION - 1)) g++-$((GCC_LATEST_VERSION - 1)) 86RUN apt-get update && apt install -y gcc-$GCC_LATEST_VERSION g++-$GCC_LATEST_VERSION 87 88# Install a recent CMake 89RUN wget https://github.com/Kitware/CMake/releases/download/v3.21.1/cmake-3.21.1-linux-x86_64.sh -O /tmp/install-cmake.sh 90RUN bash /tmp/install-cmake.sh --prefix=/usr --exclude-subdir --skip-license 91RUN rm /tmp/install-cmake.sh 92 93# Change the user to a non-root user, since some of the libc++ tests 94# (e.g. filesystem) require running as non-root. Also setup passwordless sudo. 95RUN apt-get update && apt-get install -y sudo 96RUN echo "ALL ALL = (ALL) NOPASSWD: ALL" >> /etc/sudoers 97RUN useradd --create-home libcxx-builder 98USER libcxx-builder 99WORKDIR /home/libcxx-builder 100 101# Install the Buildkite agent and dependencies. This must be done as non-root 102# for the Buildkite agent to be installed in a path where we can find it. 103RUN bash -c "$(curl -sL https://raw.githubusercontent.com/buildkite/agent/main/install.sh)" 104ENV PATH="${PATH}:/home/libcxx-builder/.buildkite-agent/bin" 105RUN echo "tags=\"queue=libcxx-builders,arch=$(uname -m),os=linux\"" >> "/home/libcxx-builder/.buildkite-agent/buildkite-agent.cfg" 106 107# By default, start the Buildkite agent (this requires a token). 108CMD buildkite-agent start 109