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

feat: install most dependencies in cachable 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
...@@ -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}
......
...@@ -126,10 +126,6 @@ FROM spack as builder ...@@ -126,10 +126,6 @@ FROM spack as builder
## Setup our custom environment (secret mount for write-enabled mirror) ## Setup our custom 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 \
...@@ -139,12 +135,36 @@ set -e ...@@ -139,12 +135,36 @@ set -e
export CCACHE_DIR=/ccache export CCACHE_DIR=/ccache
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_MIRROR="local eics3rw"
ccache --show-stats
ccache --zero-stats
EOF
## Setup our custom environment with custom versions (on top of cached layer)
ARG JUGGLER_VERSION=""
ARG EICRECON_VERSION=""
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 local
spack buildcache update-index eics3rw
spack env activate --dir ${SPACK_ENV}
if [ -n ${JUGGLER_VERSION} ] ; then
export JUGGLER_VERSION=$(jq -r .sha /tmp/juggler.json)
spack rm juggler && spack add juggler@git.${JUGGLER_VERSION}
fi
if [ -n ${EICRECON_VERSION} ] ; then
export EICRECON_VERSION=$(jq -r .sha /tmp/eicrecon.json)
spack rm eicrecon && spack add eicrecon@git.${EICRECON_VERSION}
fi
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} \
......
...@@ -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.6.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:
- '@10.1.0'
- cxxstd=20 - cxxstd=20
k4actstracking: k4actstracking:
require: require:
......
...@@ -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.
Please register or to comment