X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/c4d4088d3e7f3e3f896ed0bb482560ab702d5465..refs/heads/21666-provision-test-improvement:/build/package-build-dockerfiles/rocky8/Dockerfile diff --git a/build/package-build-dockerfiles/rocky8/Dockerfile b/build/package-build-dockerfiles/rocky8/Dockerfile index ee999a8274..1292a618bc 100644 --- a/build/package-build-dockerfiles/rocky8/Dockerfile +++ b/build/package-build-dockerfiles/rocky8/Dockerfile @@ -6,7 +6,8 @@ ARG HOSTTYPE ARG BRANCH ARG GOVERSION -FROM rockylinux:8.6-minimal as build_x86_64 +FROM rockylinux:8.8-minimal as build_x86_64 +ONBUILD ARG BRANCH # Install go ONBUILD ARG GOVERSION ONBUILD ADD generated/go${GOVERSION}.linux-amd64.tar.gz /usr/local/ @@ -17,7 +18,8 @@ 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/ -FROM rockylinux:8.6-minimal as build_aarch64 +FROM rockylinux:8.8-minimal as build_aarch64 +ONBUILD ARG BRANCH # Install go ONBUILD ARG GOVERSION ONBUILD ADD generated/go${GOVERSION}.linux-arm64.tar.gz /usr/local/ @@ -33,7 +35,8 @@ FROM build_${HOSTTYPE} MAINTAINER Arvados Package Maintainers # Install dependencies. -RUN microdnf --assumeyes --enablerepo=devel install \ +RUN microdnf --assumeyes module enable ruby:3.1 \ + && microdnf --assumeyes --enablerepo=devel install \ automake \ bison \ bzip2 \ @@ -51,15 +54,15 @@ RUN microdnf --assumeyes --enablerepo=devel install \ openssl-devel \ pam-devel \ patch \ + pkgconf \ postgresql-devel \ procps-ng \ - python3 \ - python3-devel \ - python3-pip \ - python3-virtualenv \ + python39 \ + python39-devel \ readline-devel \ rpm-build \ ruby \ + ruby-devel \ sqlite-devel \ tar \ unzip \ @@ -68,32 +71,22 @@ RUN microdnf --assumeyes --enablerepo=devel install \ xz-libs \ zlib-devel -# 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 --disable-binary 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 +# 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) -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 && \ go mod download ENV WORKSPACE /arvados -CMD ["/usr/local/rvm/bin/rvm-exec", "default", "bash", "/jenkins/run-build-packages.sh", "--target", "rocky8"] +CMD ["bash", "/jenkins/run-build-packages.sh", "--target", "rocky8"]