Skip to content

Commit

Permalink
CI: use local registry, part 3 of 3: for developers
Browse files Browse the repository at this point in the history
New tool, get-local-registry-script, intended for developers
to get a local registry running in their environment. This is
not necessary for any tests, but may be desirable for performance
reasons and/or to recreate the CI environment.

Signed-off-by: Ed Santiago <santiago@redhat.com>
  • Loading branch information
edsantiago committed Jul 8, 2024
1 parent 1eba62e commit 9c82836
Showing 1 changed file with 163 additions and 0 deletions.
163 changes: 163 additions & 0 deletions contrib/cirrus/get-local-registry-script
Original file line number Diff line number Diff line change
@@ -0,0 +1,163 @@
#!/bin/bash
#
# get-local-registry-script - fetches local-registry script from automation_images repo
#
ME=$(basename $0)

###############################################################################
# BEGIN global settings

SCRIPTNAME=cache_images/local-cache-registry

REPO=containers/automation_images

GITHUB_GRAPHQL=https://api.github.com/graphql

# END global settings
###############################################################################

usage="Usage: $ME [--help] [-v|--verbose] [IMG_SFX]
--help display usage message
-v, --verbose verbose output
$ME fetches the $SCRIPTNAME tool
from the github $REPO repo.
If successful, the script will be left in cwd.
It is up to you to invoke it:
\$ sudo ./$(basename $SCRIPTNAME) initialize
This will set up a local registry and prepopulate it with
images used in tests. Initialization may take tens of minutes
on a slow connection.
To use this registry in e2e or apiv2 tests:
export CI_USE_REGISTRY_CACHE=1
To use in system tests, you need to overwrite /etc/containers/registries.conf
because system tests, by definition, use system settings. This is left as
an exercise for the reader.
Reasons for doing this:
1) Consistency with CI environment
2) Speedier (and less flaky) tests
"

verbose=
for i; do
value=`expr "$i" : '[^=]*=\(.*\)'`
case "$i" in
-h*|--help) echo "$usage"; exit 0;;
-v|--verbose) verbose=$i; shift;;
-*) echo "$ME: unrecognized option $i" >&2
echo "$usage" >&2
exit 1;;
*) break;;
esac
done

###############################################################################
# BEGIN helper functions

function die() {
echo "$ME: $*" >&2
exit 1
}

function get_imgsfx() {
test -e .cirrus.yml || die ".cirrus.yml does not exist; please run me from top of repo"

imgsfx=$(sed -ne 's/^ *IMAGE_SUFFIX:.*"c\(202.*\)"/\1/p' <.cirrus.yml)
if [[ -z "$imgsfx" ]]; then
die "Did not find 'IMAGE_SUFFIX:.*c202.*' in .cirrus.yml"
fi

expr "$imgsfx" : "^20[0-9]\{6\}t[0-9]\{6\}z-" &> /dev/null || die "IMAGE_SUFFIX '$imgsfx' (from .cirrus.yml) does not match expected YYYYMMDDtHHMMSS-* form"

echo $imgsfx
}

function get_script() {
local tag=$1

local tmpfile=$(mktemp --tmpdir --suffix=.sh $ME.fetched-script.XXXXXXX)

local url="https://raw.githubusercontent.com/${REPO}/$tag/$SCRIPTNAME"
test -n "$verbose" && echo "[ $url ]" >&2

curl -s -f -o $tmpfile $url
if [[ $? -eq 0 ]]; then
chmod 755 $tmpfile
mv -f $tmpfile $SCRIPTNAME
echo $SCRIPTNAME
return
fi
rm -f $tmpfile
}

# END helper functions
###############################################################################
# BEGIN code

if [[ -n "$1" ]]; then
imgsfx=$1
shift
if [[ -n "$*" ]]; then
die "Too many arguments; run $ME --help for help"
fi
else
imgsfx=$(get_imgsfx)
fi
test -n "$verbose" && echo "[ imgsfx=$imgsfx ]" >&2

# Easy case: this is a tagged automation_images build
fetched_script=$(get_script $imgsfx)
if [[ -n "$fetched_script" ]]; then
echo $fetched_script
exit 0
fi

# Nope, not a tagged build. Look for imgsfx in PR
query="
{
\"query\": \"{
search(query: \\\"repo:$REPO is:pr c$imgsfx\\\", type:ISSUE, first:10) {
edges {
node { ... on PullRequest {
number
title
commits(last:30) { nodes { commit { committedDate, oid } } }
comments(last:30) { nodes { createdAt author { login } body } }
}
}
}
}
}\"
}
"

query_clean=$(tr -d \\012 <<<"$query")

jsontmp=$(mktemp --tmpdir --suffix=.json $ME.graphql.XXXXXXX)

curl -s -S -H "Authorization: bearer $GITHUB_TOKEN" -X POST --data "$query_clean" $GITHUB_GRAPHQL > $jsontmp

# There should be one and exactly one comment from github-actions
# that mentions the given imgsfx. Find its timestamp
img_timestamp=$(jq -C -r '.data.search.edges.[].node.comments.nodes.[] | select(.author.login="github-actions") | select(.body | contains("c'${imgsfx}'")).createdAt' < $jsontmp)
if [[ -z "$img_timestamp" ]]; then
die "Did not find a github-actions comment mentioning '$imgsfx'"
fi

# Some time prior to that comment, there was a commit pushed to github
# that resulted in that build. Find that commit's SHA (OID).
push_sha=$(jq -C -r '.data.search.edges.[].node.commits.nodes.[].commit | select(.committedDate < "'${img_timestamp}'").oid' < $jsontmp)

# Got all the info we need. Clean up tmpfile
rm -f $jsontmp

# This must succeed.
get_script $push_sha

0 comments on commit 9c82836

Please sign in to comment.