Tweak build/clone logic to always do a checkout, and to bail gracefully when a commit doesn't exist (skipping the relevant repoTag build)
This commit is contained in:
parent
4b6f49153d
commit
845488129d
41
build.sh
41
build.sh
|
|
@ -193,27 +193,32 @@ while [ "$#" -gt 0 ]; do
|
||||||
|
|
||||||
echo "Processing $repoTag ..."
|
echo "Processing $repoTag ..."
|
||||||
|
|
||||||
if [ "$doClone" ]; then
|
if ! ( cd "$gitRepo" && git rev-parse --verify "${gitRef}^{commit}" &> /dev/null ); then
|
||||||
( cd "$gitRepo" && git clean -dfxq && git checkout -q "$gitRef" && "$dir/git-set-dir-times" )
|
echo "- skip; invalid ref: $gitRef"
|
||||||
# TODO git tag
|
continue
|
||||||
|
|
||||||
IFS=$'\n'
|
|
||||||
froms=( $(grep '^FROM[[:space:]]' "$gitRepo/$gitDir/Dockerfile" | awk -F '[[:space:]]+' '{ print $2 ~ /:/ ? $2 : $2":latest" }') )
|
|
||||||
unset IFS
|
|
||||||
|
|
||||||
for from in "${froms[@]}"; do
|
|
||||||
for queuedRepoTag in "$@"; do
|
|
||||||
if [ "$from" = "$queuedRepoTag" ]; then
|
|
||||||
# a "FROM" in this image is being built later in our queue, so let's bail on this image for now and come back later
|
|
||||||
echo "- defer; FROM $from"
|
|
||||||
set -- "$@" "$repoTag"
|
|
||||||
continue 3
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
done
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
( cd "$gitRepo" && git clean -dfxq && git checkout -q "$gitRef" )
|
||||||
|
# TODO git tag
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
froms=( $(grep '^FROM[[:space:]]' "$gitRepo/$gitDir/Dockerfile" | awk -F '[[:space:]]+' '{ print $2 ~ /:/ ? $2 : $2":latest" }') )
|
||||||
|
unset IFS
|
||||||
|
|
||||||
|
for from in "${froms[@]}"; do
|
||||||
|
for queuedRepoTag in "$@"; do
|
||||||
|
if [ "$from" = "$queuedRepoTag" ]; then
|
||||||
|
# a "FROM" in this image is being built later in our queue, so let's bail on this image for now and come back later
|
||||||
|
echo "- defer; FROM $from"
|
||||||
|
set -- "$@" "$repoTag"
|
||||||
|
continue 3
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
done
|
||||||
|
|
||||||
if [ "$doBuild" ]; then
|
if [ "$doBuild" ]; then
|
||||||
|
( cd "$gitRepo/$gitDir" && "$dir/git-set-dir-times" )
|
||||||
|
|
||||||
thisLog="$logDir/build-$repoTag.log"
|
thisLog="$logDir/build-$repoTag.log"
|
||||||
touch "$thisLog"
|
touch "$thisLog"
|
||||||
ln -sf "$thisLog" "$latestLogDir/$(basename "$thisLog")"
|
ln -sf "$thisLog" "$latestLogDir/$(basename "$thisLog")"
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue