refactor(ops/pipelines): Generalise fetch-parent-targets script
Removes all TVL-specific values in favour of environment variables supplied by Buildkite. This makes it possible to reuse this script outside of TVL. Change-Id: Ic543bc41e4c81e65ee349ad241c515231e97ab30 Reviewed-on: https://cl.tvl.fyi/c/depot/+/5005 Tested-by: BuildkiteCI Autosubmit: tazjin <tazjin@tvl.su> Reviewed-by: ezemtsov <eugene.zemtsov@gmail.com>
This commit is contained in:
parent
f0aa5ae3a2
commit
c2e6c0719c
2 changed files with 15 additions and 14 deletions
|
@ -3,38 +3,39 @@ set -ueo pipefail
|
||||||
|
|
||||||
# Each Buildkite build stores the derivation target map as a pipeline
|
# Each Buildkite build stores the derivation target map as a pipeline
|
||||||
# artifact. This script determines the most appropriate commit (the
|
# artifact. This script determines the most appropriate commit (the
|
||||||
# fork point of the current chain from canon) and fetches the
|
# fork point of the current chain from HEAD) and fetches the artifact.
|
||||||
# artifact.
|
|
||||||
#
|
#
|
||||||
# Since builds can be based on canon before the pipeline for the last
|
# New builds can be based on HEAD before the pipeline for the last
|
||||||
# commit has finished, it is possible that the fork point has no
|
# commit has finished, in which case it is possible that the fork
|
||||||
# target map. To account for this, we will go up to 3 commits back in
|
# point has no derivation map. To account for this, up to 3 commits
|
||||||
# time to find a map.
|
# prior to HEAD are also queried to find a map.
|
||||||
#
|
#
|
||||||
# If no map is found, the failure mode is not critical: We simply
|
# If no map is found, the failure mode is not critical: We simply
|
||||||
# build all targets.
|
# build all targets.
|
||||||
|
|
||||||
|
: ${DRVMAP_PATH:=pipeline/drvmap.json}
|
||||||
|
|
||||||
function most_relevant_builds {
|
function most_relevant_builds {
|
||||||
git fetch -v origin canon
|
git fetch -v origin "${BUILDKITE_PIPELINE_DEFAULT_BRANCH}"
|
||||||
local FIRST=$(git merge-base --fork-point HEAD origin/canon)
|
local FIRST=$(git merge-base --fork-point HEAD FETCH_HEAD)
|
||||||
local SECOND=$(git rev-parse "$FIRST~1")
|
local SECOND=$(git rev-parse "$FIRST~1")
|
||||||
local THIRD=$(git rev-parse "$FIRST~2")
|
local THIRD=$(git rev-parse "$FIRST~2")
|
||||||
|
|
||||||
curl 'https://graphql.buildkite.com/v1' \
|
curl 'https://graphql.buildkite.com/v1' \
|
||||||
--silent \
|
--silent \
|
||||||
-H "Authorization: Bearer $(cat /run/agenix/buildkite-graphql-token)" \
|
-H "Authorization: Bearer $(cat /run/agenix/buildkite-graphql-token)" \
|
||||||
-d "{\"query\": \"query { pipeline(slug: \\\"tvl/depot\\\") { builds(commit: [\\\"$FIRST\\\",\\\"$SECOND\\\",\\\"$THIRD\\\"]) { edges { node { uuid }}}}}\"}" | \
|
-d "{\"query\": \"query { pipeline(slug: \\\"$BUILDKITE_ORGANIZATION_SLUG/$BUILDKITE_PIPELINE_SLUG\\\") { builds(commit: [\\\"$FIRST\\\",\\\"$SECOND\\\",\\\"$THIRD\\\"]) { edges { node { uuid }}}}}\"}" | \
|
||||||
jq -r '.data.pipeline.builds.edges[] | .node.uuid'
|
jq -r '.data.pipeline.builds.edges[] | .node.uuid'
|
||||||
}
|
}
|
||||||
|
|
||||||
mkdir -p tmp
|
mkdir -p tmp
|
||||||
for build in $(most_relevant_builds); do
|
for build in $(most_relevant_builds); do
|
||||||
echo "Checking artifacts for build $build"
|
echo "Checking artifacts for build $build"
|
||||||
buildkite-agent artifact download --build "${build}" 'pipeline/drvmap.json' 'tmp/' || true
|
buildkite-agent artifact download --build "${build}" "${DRVMAP_PATH}" 'tmp/' || true
|
||||||
|
|
||||||
if [[ -f "tmp/pipeline/drvmap.json" ]]; then
|
if [[ -f "tmp/${DRVMAP_PATH}" ]]; then
|
||||||
echo "Fetched target map from build ${build}"
|
echo "Fetched target map from build ${build}"
|
||||||
mv tmp/pipeline/drvmap.json parent-target-map.json
|
mv "tmp/${DRVMAP_PATH}" tmp/parent-target-map.json
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
|
@ -21,8 +21,8 @@ steps:
|
||||||
ops/pipelines/fetch-parent-targets.sh
|
ops/pipelines/fetch-parent-targets.sh
|
||||||
|
|
||||||
PIPELINE_ARGS=""
|
PIPELINE_ARGS=""
|
||||||
if [[ -f ./parent-target-map.json ]]; then
|
if [[ -f tmp/parent-target-map.json ]]; then
|
||||||
PIPELINE_ARGS="--arg parentTargetMap ./parent-target-map.json"
|
PIPELINE_ARGS="--arg parentTargetMap tmp/parent-target-map.json"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
nix-build -A ops.pipelines.depot -o pipeline --show-trace $$PIPELINE_ARGS
|
nix-build -A ops.pipelines.depot -o pipeline --show-trace $$PIPELINE_ARGS
|
||||||
|
|
Loading…
Reference in a new issue