X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3197db7788e10b33fb496bfe86c836382f723ff1..HEAD:/build/package-build-dockerfiles/ubuntu2004/Dockerfile diff --git a/build/package-build-dockerfiles/ubuntu2004/Dockerfile b/build/package-build-dockerfiles/ubuntu2004/Dockerfile index da45077a42..dc57c8c03f 100644 --- a/build/package-build-dockerfiles/ubuntu2004/Dockerfile +++ b/build/package-build-dockerfiles/ubuntu2004/Dockerfile @@ -7,13 +7,16 @@ ARG BRANCH ARG GOVERSION FROM ubuntu:focal as build_x86_64 +ONBUILD ARG BRANCH # Install go ONBUILD ARG GOVERSION ONBUILD ADD generated/go${GOVERSION}.linux-amd64.tar.gz /usr/local/ ONBUILD RUN ln -s /usr/local/go/bin/go /usr/local/bin/ # Install nodejs and npm -ONBUILD ADD generated/node-v10.23.1-linux-x64.tar.xz /usr/local/ -ONBUILD RUN ln -s /usr/local/node-v10.23.1-linux-x64/bin/* /usr/local/bin/ +ONBUILD ADD generated/node-v12.22.12-linux-x64.tar.xz /usr/local/ +ONBUILD RUN ln -s /usr/local/node-v12.22.12-linux-x64/bin/* /usr/local/bin/ +ONBUILD RUN npm install -g yarn +ONBUILD RUN ln -sf /usr/local/node-v12.22.12-linux-x64/bin/* /usr/local/bin/ # On x86, we want some cross-compilation support for arm64 # Add gcc-aarch64-linux-gnu to compile go binaries for arm64 ONBUILD RUN /usr/bin/apt-get update && /usr/bin/apt-get install -q -y gcc-aarch64-linux-gnu @@ -28,13 +31,16 @@ ONBUILD RUN /usr/bin/apt-get update && /usr/bin/apt-get install -o APT::Immediat # ubuntu2204 will have the fix introduced in debian11. FROM ubuntu:focal as build_aarch64 +ONBUILD ARG BRANCH # Install go ONBUILD ARG GOVERSION ONBUILD ADD generated/go${GOVERSION}.linux-arm64.tar.gz /usr/local/ ONBUILD RUN ln -s /usr/local/go/bin/go /usr/local/bin/ # Install nodejs and npm -ONBUILD ADD generated/node-v10.23.1-linux-arm64.tar.xz /usr/local/ -ONBUILD RUN ln -s /usr/local/node-v10.23.1-linux-arm64/bin/* /usr/local/bin/ +ONBUILD ADD generated/node-v12.22.12-linux-arm64.tar.xz /usr/local/ +ONBUILD RUN ln -s /usr/local/node-v12.22.12-linux-arm64/bin/* /usr/local/bin/ +ONBUILD RUN npm install -g yarn +ONBUILD RUN ln -sf /usr/local/node-v12.22.12-linux-arm64/bin/* /usr/local/bin/ FROM build_${HOSTTYPE} @@ -44,40 +50,43 @@ ENV DEBIAN_FRONTEND noninteractive SHELL ["/bin/bash", "-c"] # Install dependencies. -RUN /usr/bin/apt-get update && /usr/bin/apt-get install -q -y python3 python3-pip libcurl4-gnutls-dev libgnutls28-dev curl git libattr1-dev libfuse-dev libpq-dev unzip tzdata python3-venv python3-dev libpam-dev shared-mime-info equivs +RUN /usr/bin/apt-get update && /usr/bin/apt-get install -q -y \ + build-essential \ + curl \ + equivs \ + git \ + libattr1-dev \ + libcurl4-gnutls-dev \ + libfuse-dev \ + libgnutls28-dev \ + libpam-dev \ + libpq-dev \ + pkgconf \ + python3 \ + python3-dev \ + python3-venv \ + ruby \ + ruby-dev \ + shared-mime-info \ + tzdata \ + unzip -# Install virtualenv -RUN /usr/bin/pip3 install 'virtualenv<20' +# fpm depends on dotenv, but version 3.0 of that gem dropped support for +# Ruby 2.7, so we need to specifically install an older version. +RUN echo "gem: --no-document" >> ~/.gemrc && \ + gem install --conservative --version '~> 2.4.0' bundler && \ + gem install dotenv --version '~> 2.8' && \ + gem install fpm --version 1.15.1 && \ + bundle config --global jobs $(let a=$(grep -c processor /proc/cpuinfo )-1; echo $a) -# Install RVM -ADD generated/mpapis.asc /tmp/ -ADD generated/pkuczynski.asc /tmp/ -RUN gpg --import --no-tty /tmp/mpapis.asc && \ - gpg --import --no-tty /tmp/pkuczynski.asc && \ - curl -L https://get.rvm.io | bash -s stable && \ - /usr/local/rvm/bin/rvm install 2.7 -j $(grep -c processor /proc/cpuinfo) && \ - /usr/local/rvm/bin/rvm alias create default ruby-2.7 && \ - echo "gem: --no-document" >> ~/.gemrc && \ - /usr/local/rvm/bin/rvm-exec default gem install bundler --version 2.2.19 && \ - /usr/local/rvm/bin/rvm-exec default gem install fpm --version 1.10.2 - -RUN /usr/local/rvm/bin/rvm-exec default bundle config --global jobs $(let a=$(grep -c processor /proc/cpuinfo )-1; echo $a) # Cf. https://build.betterup.com/one-weird-trick-that-will-speed-up-your-bundle-install/ ENV MAKE "make --jobs $(grep -c processor /proc/cpuinfo)" -# Preseed the go module cache and the ruby gems, using the currently checked -# out branch of the source tree. This avoids potential compatibility issues -# between the version of Ruby and certain gems. -RUN git clone --depth 1 git://git.arvados.org/arvados.git /tmp/arvados && \ +# Preseed the go module cache. +RUN git clone git://git.arvados.org/arvados.git /tmp/arvados && \ cd /tmp/arvados && \ if [[ -n "${BRANCH}" ]]; then git checkout ${BRANCH}; fi && \ - cd /tmp/arvados/services/api && \ - /usr/local/rvm/bin/rvm-exec default bundle install && \ - cd /tmp/arvados/apps/workbench && \ - /usr/local/rvm/bin/rvm-exec default bundle install && \ - cd /tmp/arvados && \ go mod download - ENV WORKSPACE /arvados -CMD ["/usr/local/rvm/bin/rvm-exec", "default", "bash", "/jenkins/run-build-packages.sh", "--target", "ubuntu2004"] +CMD ["bash", "/jenkins/run-build-packages.sh", "--target", "ubuntu2004"]