Improvements to build-all-docker-images script

Trap interrupt signal so that the build-all-docker-images script is
stopped on Ctrl-C, and not only the current build.

Additionally, the script now prints a summary of changes on exit.

Change-Id: I3f6ef97d776c7799c73bc709070d97d37406637a
This commit is contained in:
Martin André 2015-01-07 15:30:47 +09:00
parent 5baafd1dff
commit 9723a796d3

View File

@ -47,7 +47,7 @@ function requires_build {
function build_image {
local dir=$1
if [[ -x "$dir/build" ]]; then
if [ -x "$dir/build" ]; then
printf "\n"
info "Building image in $dir"
if $dir/build $ARGS; then
@ -55,6 +55,7 @@ function build_image {
status[$image]="rebuilt"
else
warn "Failed to build image in $dir"
status[$image]="fail"
fi
fi
}
@ -65,9 +66,7 @@ function init_image {
set_defaults
[ -f $TOPDIR/.buildconf ] && . $TOPDIR/.buildconf
[ -f $img_dir/.buildconf ] && . $img_dir/.buildconf
if [ ! -z $FORCE_NAMESPACE ]; then
NAMESPACE=$FORCE_NAMESPACE
fi
[ -n $FORCE_NAMESPACE ] && NAMESPACE=$FORCE_NAMESPACE
local image="${NAMESPACE:+${NAMESPACE}/}${PREFIX}${img_dir##*/}"
local base_image=$(cat $img_dir/Dockerfile | gawk 'match($0, /^\s*FROM\s+(\S+)/, matches) {print matches[1]}' )
@ -81,17 +80,34 @@ function init_image {
function process_image {
local image=$1
if [ ${dependency[$image]} ]; then
if [ -n ${dependency[$image]} ]; then
process_image ${dependency[$image]}
fi
if requires_build $image; then
build_image ${img_dirs[$image]}
fi
if [ -z ${status[$image]} ]; then
status[$image]="processed"
if [ -z "${status[$image]}" ]; then
status[$image]="up-to-date"
fi
}
function print_summary {
printf "\nSummary\n=======\n"
for image in "${!status[@]}"; do
case "${status[$image]}" in
("fail") warn "Failed to process $image" ;;
("rebuilt") success "Rebuilt $image" ;;
(*) info "$image: ${status[$image]}" ;;
esac
done
}
function interrupted {
info "Interrupted..."
print_summary
exit 1
}
function usage () {
read -r -d '' HELP <<EOF
A wrapper to build-docker-image that build all images in order.
@ -106,6 +122,8 @@ EOF
printf "%s\n" "${HELP/$TOPDIR\/tools\/build-docker-image/$0}"
}
trap 'interrupted' INT
ARGS=$@
PARSED_ARGS=$(getopt -q -o hn: -l help,namespace:,from:,to: -- "$@")
@ -154,9 +172,4 @@ for image in "${!img_dirs[@]}"; do
process_image $image
done
# Report failed images
for image in "${!status[@]}"; do
if [ -z ${status[$image]} ]; then
warn "Failed to process $image"
fi
done
print_summary