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 { function build_image {
local dir=$1 local dir=$1
if [[ -x "$dir/build" ]]; then if [ -x "$dir/build" ]; then
printf "\n" printf "\n"
info "Building image in $dir" info "Building image in $dir"
if $dir/build $ARGS; then if $dir/build $ARGS; then
@ -55,6 +55,7 @@ function build_image {
status[$image]="rebuilt" status[$image]="rebuilt"
else else
warn "Failed to build image in $dir" warn "Failed to build image in $dir"
status[$image]="fail"
fi fi
fi fi
} }
@ -65,9 +66,7 @@ function init_image {
set_defaults set_defaults
[ -f $TOPDIR/.buildconf ] && . $TOPDIR/.buildconf [ -f $TOPDIR/.buildconf ] && . $TOPDIR/.buildconf
[ -f $img_dir/.buildconf ] && . $img_dir/.buildconf [ -f $img_dir/.buildconf ] && . $img_dir/.buildconf
if [ ! -z $FORCE_NAMESPACE ]; then [ -n $FORCE_NAMESPACE ] && NAMESPACE=$FORCE_NAMESPACE
NAMESPACE=$FORCE_NAMESPACE
fi
local image="${NAMESPACE:+${NAMESPACE}/}${PREFIX}${img_dir##*/}" 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]}' ) 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 { function process_image {
local image=$1 local image=$1
if [ ${dependency[$image]} ]; then if [ -n ${dependency[$image]} ]; then
process_image ${dependency[$image]} process_image ${dependency[$image]}
fi fi
if requires_build $image; then if requires_build $image; then
build_image ${img_dirs[$image]} build_image ${img_dirs[$image]}
fi fi
if [ -z ${status[$image]} ]; then if [ -z "${status[$image]}" ]; then
status[$image]="processed" status[$image]="up-to-date"
fi 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 () { function usage () {
read -r -d '' HELP <<EOF read -r -d '' HELP <<EOF
A wrapper to build-docker-image that build all images in order. 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}" printf "%s\n" "${HELP/$TOPDIR\/tools\/build-docker-image/$0}"
} }
trap 'interrupted' INT
ARGS=$@ ARGS=$@
PARSED_ARGS=$(getopt -q -o hn: -l help,namespace:,from:,to: -- "$@") PARSED_ARGS=$(getopt -q -o hn: -l help,namespace:,from:,to: -- "$@")
@ -154,9 +172,4 @@ for image in "${!img_dirs[@]}"; do
process_image $image process_image $image
done done
# Report failed images print_summary
for image in "${!status[@]}"; do
if [ -z ${status[$image]} ]; then
warn "Failed to process $image"
fi
done