Skip to content
Snippets Groups Projects
Commit be65f11d authored by Wouter Deconinck's avatar Wouter Deconinck
Browse files

feat: install most dependencies in cacheable layer, before adding main

parent 18374c47
No related branches found
No related tags found
1 merge request!747feat: install most dependencies in cacheable layer, before adding main
...@@ -5,10 +5,10 @@ variables: ...@@ -5,10 +5,10 @@ variables:
DOCKER_IMAGE: docker.io/docker:24.0.7 DOCKER_IMAGE: docker.io/docker:24.0.7
SINGULARITY_IMAGE: quay.io/singularity/singularity:v3.11.5 SINGULARITY_IMAGE: quay.io/singularity/singularity:v3.11.5
## Application versions used for the main release ## Default versions are specified in packages.yaml but can be overridden
## note: nightly builds will always use the master/main branch ## note: nightly builds will always use the master/main branch
JUGGLER_VERSION: "v13.0.0" JUGGLER_VERSION: ""
EICRECON_VERSION: "v1.9.1" EICRECON_VERSION: ""
## Local registry ## Local registry
CI_PUSH: 1 CI_PUSH: 1
...@@ -337,8 +337,12 @@ jug_dev: ...@@ -337,8 +337,12 @@ jug_dev:
--build-arg S3_SECRET_KEY=${S3_SECRET_KEY} --build-arg S3_SECRET_KEY=${S3_SECRET_KEY}
--build-arg JUG_VERSION=${EXPORT_TAG}-${BUILD_TYPE}-$(git rev-parse HEAD) --build-arg JUG_VERSION=${EXPORT_TAG}-${BUILD_TYPE}-$(git rev-parse HEAD)
${IF_BUILD_DEFAULT:+ ${IF_BUILD_DEFAULT:+
--build-arg JUGGLER_VERSION=${JUGGLER_VERSION} ${JUGGLER_VERSION:+--build-arg JUGGLER_VERSION=${JUGGLER_VERSION}}
--build-arg EICRECON_VERSION=${EICRECON_VERSION} ${EICRECON_VERSION:+--build-arg EICRECON_VERSION=${EICRECON_VERSION}}
}
${IF_BUILD_NIGHTLY:+
--build-arg JUGGLER_VERSION=main
--build-arg EICRECON_VERSION=main
} }
--build-arg ENV=${ENV} --build-arg ENV=${ENV}
--build-arg jobs=${JOBS} --build-arg jobs=${JOBS}
......
...@@ -123,13 +123,9 @@ EOF ...@@ -123,13 +123,9 @@ EOF
## ======================================================================================== ## ========================================================================================
FROM spack as builder FROM spack as builder
## Setup our custom environment (secret mount for write-enabled mirror) ## 1. Setup our default environment (secret mount for write-enabled mirror)
COPY --from=spack-environment . /opt/spack-environment/ COPY --from=spack-environment . /opt/spack-environment/
ARG ENV=dev ARG ENV=dev
ARG JUGGLER_VERSION="main"
ADD https://api.github.com/repos/eic/juggler/commits/${JUGGLER_VERSION} /tmp/juggler.json
ARG EICRECON_VERSION="main"
ADD https://api.github.com/repos/eic/eicrecon/commits/${EICRECON_VERSION} /tmp/eicrecon.json
ENV SPACK_ENV=/opt/spack-environment/${ENV} ENV SPACK_ENV=/opt/spack-environment/${ENV}
RUN --mount=type=cache,target=/ccache,id=${TARGETPLATFORM} \ RUN --mount=type=cache,target=/ccache,id=${TARGETPLATFORM} \
--mount=type=cache,target=/var/cache/spack \ --mount=type=cache,target=/var/cache/spack \
...@@ -137,14 +133,47 @@ RUN --mount=type=cache,target=/ccache,id=${TARGETPLATFORM} \ ...@@ -137,14 +133,47 @@ RUN --mount=type=cache,target=/ccache,id=${TARGETPLATFORM} \
<<EOF <<EOF
set -e set -e
export CCACHE_DIR=/ccache export CCACHE_DIR=/ccache
source ${SPACK_ROOT}/share/spack/setup-env.sh
mkdir -p /var/cache/spack/blobs/sha256/ mkdir -p /var/cache/spack/blobs/sha256/
find /var/cache/spack/blobs/sha256/ -atime +7 -delete find /var/cache/spack/blobs/sha256/ -atime +7 -delete
JUGGLER_VERSION=$(jq -r .sha /tmp/juggler.json)
EICRECON_VERSION=$(jq -r .sha /tmp/eicrecon.json)
spack buildcache update-index eics3rw spack buildcache update-index eics3rw
spack env activate --dir ${SPACK_ENV} spack env activate --dir ${SPACK_ENV}
spack add juggler@git.${JUGGLER_VERSION} spack concretize --fresh --force --quiet
spack add eicrecon@git.${EICRECON_VERSION} make --jobs ${jobs} --keep-going --directory /opt/spack-environment \
SPACK_ENV=${SPACK_ENV} \
BUILDCACHE_OCI_PROMPT="eicweb" \
BUILDCACHE_OCI_FINAL="ghcr" \
BUILDCACHE_S3_FINAL="eics3rw"
ccache --show-stats
ccache --zero-stats
EOF
## 2. Setup our environment with custom versions (on top of cached layer)
## Note: these default versions are just the very first commit.
ARG JUGGLER_VERSION="df87bf1f8643afa8e80bece9d36d6dc26dfe8132"
ARG EICRECON_VERSION="28108da4a1e8919a05dfdb5f11e114800a2cbe96"
ADD https://api.github.com/repos/eic/juggler/commits/${JUGGLER_VERSION} /tmp/juggler.json
ADD https://api.github.com/repos/eic/eicrecon/commits/${EICRECON_VERSION} /tmp/eicrecon.json
RUN --mount=type=cache,target=/ccache,id=${TARGETPLATFORM} \
--mount=type=cache,target=/var/cache/spack \
--mount=type=secret,id=mirrors,target=/opt/spack/etc/spack/mirrors.yaml \
<<EOF
source ${SPACK_ROOT}/share/spack/setup-env.sh
export CCACHE_DIR=/ccache
spack buildcache update-index eics3rw
spack env activate --dir ${SPACK_ENV}
if [ "${JUGGLER_VERSION}" != "df87bf1f8643afa8e80bece9d36d6dc26dfe8132" ] ; then
export JUGGLER_VERSION=$(jq -r .sha /tmp/juggler.json)
spack config add "packages:juggler::require:['@git.${JUGGLER_VERSION}=main']"
spack deconcretize -y juggler
fi
if [ "${EICRECON_VERSION}" != "28108da4a1e8919a05dfdb5f11e114800a2cbe96" ] ; then
export EICRECON_VERSION=$(jq -r .sha /tmp/eicrecon.json)
spack config add "packages:eicrecon::require:['@git.${EICRECON_VERSION}=main']"
spack deconcretize -y eicrecon
fi
cat ${SPACK_ENV}/spack.yaml
cat ${SPACK_ENV}/../packages.yaml
spack concretize --fresh --force --quiet spack concretize --fresh --force --quiet
make --jobs ${jobs} --keep-going --directory /opt/spack-environment \ make --jobs ${jobs} --keep-going --directory /opt/spack-environment \
SPACK_ENV=${SPACK_ENV} \ SPACK_ENV=${SPACK_ENV} \
......
...@@ -3,7 +3,7 @@ EICSPACK_ORGREPO="eic/eic-spack" ...@@ -3,7 +3,7 @@ EICSPACK_ORGREPO="eic/eic-spack"
## EIC spack commit hash or github version, e.g. v0.19.7 ## EIC spack commit hash or github version, e.g. v0.19.7
## note: nightly builds could use a branch e.g. releases/v0.19 ## note: nightly builds could use a branch e.g. releases/v0.19
EICSPACK_VERSION="5d8ba97ea6b021a50aa11e924a55a4726c689d65" EICSPACK_VERSION="bc6a4382636dd8c8bcd8c665163840815d48a25e"
## Space-separated list of eic-spack cherry-picks ## Space-separated list of eic-spack cherry-picks
read -r -d '' EICSPACK_CHERRYPICKS <<- \ read -r -d '' EICSPACK_CHERRYPICKS <<- \
......
...@@ -24,6 +24,7 @@ spack: ...@@ -24,6 +24,7 @@ spack:
- edm4eic - edm4eic
- edm4hep - edm4hep
- eic-smear - eic-smear
- eicrecon
- eigen - eigen
- emacs - emacs
- fastjet - fastjet
...@@ -40,6 +41,7 @@ spack: ...@@ -40,6 +41,7 @@ spack:
- iwyu - iwyu
- jana2 - jana2
- k4actstracking - k4actstracking
- juggler
- k4fwcore - k4fwcore
- lcov - lcov
- lhapdf - lhapdf
......
...@@ -92,6 +92,9 @@ packages: ...@@ -92,6 +92,9 @@ packages:
eic-smear: eic-smear:
require: require:
- '@1.1.12' - '@1.1.12'
eicrecon:
require:
- '@1.9.1'
eigen: eigen:
require: require:
- '@3.4.0' - '@3.4.0'
...@@ -160,6 +163,7 @@ packages: ...@@ -160,6 +163,7 @@ packages:
- -ipo +podio +root +zmq - -ipo +podio +root +zmq
juggler: juggler:
require: require:
- '@13.0.0'
- cxxstd=20 - cxxstd=20
k4actstracking: k4actstracking:
require: require:
......
spack: spack:
include: include:
- ../concretizer.yaml - ../concretizer.yaml
- ../packages.yaml - ../packages.yaml
config: config:
...@@ -9,6 +9,7 @@ spack: ...@@ -9,6 +9,7 @@ spack:
- cmake - cmake
- dd4hep -ddeve - dd4hep -ddeve
- edm4eic - edm4eic
- eicrecon
- fastjet - fastjet
- fjcontrib - fjcontrib
- gaudi - gaudi
...@@ -17,6 +18,7 @@ spack: ...@@ -17,6 +18,7 @@ spack:
- intel-tbb - intel-tbb
- irt - irt
- jana2 - jana2
- juggler
- npsim -geocad - npsim -geocad
- py-boto3 - py-boto3
- py-jinja2 - py-jinja2
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment