From 67c7b12cb1731b30c87c051e78620617cbd5105d Mon Sep 17 00:00:00 2001 From: Bernhard Ehlers Date: Fri, 15 Dec 2023 19:51:41 +0100 Subject: [PATCH] Docker build tool renamed to docker_make The build tool behaves more like make, it builds only the changed images. --- .github/bin/{docker_build => docker_make} | 6 +++--- .github/{docker_build.md => docker_make.md} | 12 ++++++------ .github/workflows/build-docker-images.yml | 2 +- 3 files changed, 10 insertions(+), 10 deletions(-) rename .github/bin/{docker_build => docker_make} (99%) rename .github/{docker_build.md => docker_make.md} (93%) diff --git a/.github/bin/docker_build b/.github/bin/docker_make similarity index 99% rename from .github/bin/docker_build rename to .github/bin/docker_make index a35e567..76837de 100755 --- a/.github/bin/docker_build +++ b/.github/bin/docker_make @@ -16,10 +16,10 @@ # along with this program. If not, see . """ -docker_build - (re)build outdated docker images +docker_make - (re)build outdated docker images -usage: docker_build [--help] [--all] [--dir DIR] [--dry-run] [--file FILE] - [image ...] +usage: docker_make [--help] [--all] [--dir DIR] [--dry-run] [--file FILE] + [image ...] positional arguments: image images to build additionally diff --git a/.github/docker_build.md b/.github/docker_make.md similarity index 93% rename from .github/docker_build.md rename to .github/docker_make.md index 9de2159..a7f624f 100644 --- a/.github/docker_build.md +++ b/.github/docker_make.md @@ -18,17 +18,17 @@ files, that got an update. Then a manual trigger is needed. ## Build Tool -The `docker_build` tool reads a configuration file and +The `docker_make` tool reads a configuration file and then starts building images with `docker buildx build`. -If `docker_build` is launched without arguments, it checks +If `docker_make` is launched without arguments, it checks all configured images for an update of the base image. Additionally it checks, if `git` shows an update of the directory containing the docker build context. When at least one of these conditions is met, the tool starts a rebuild of that image. -When `docker_build` is run with some image names as +When `docker_make` is run with some image names as arguments, then these images are additionally built. When using a base image name as an argument, then all images with that base image are rebuilt. @@ -72,7 +72,7 @@ The target image may contain the full name, in which case it will contain one or more '/' characters. Another option is to specify only the last part of the -image name. Then `docker_build` uses the `DOCKER_REPOSITORY` +image name. Then `docker_make` uses the `DOCKER_REPOSITORY` environment variable as its initial part. For example, an DOCKER_REPOSITORY value of "ghcr.io/b-ehlers" plus the image name of "alpine-1" results in "ghcr.io/b-ehlers/alpine-1". @@ -118,7 +118,7 @@ DOCKER_LOGIN_GH="ghcr.io github-user github-password" uses YAML files in the .github/workflows directory to define, which tasks should be run. -Before `docker_build` can be run the following steps +Before `docker_make` can be run the following steps need to be done: * Check out the repository code @@ -127,7 +127,7 @@ need to be done: * Login to the Container Registries * Install python requirements -Then `docker_build` can be executed, +Then `docker_make` can be executed, normally without any arguments. But what, when an image build needs to be forced? diff --git a/.github/workflows/build-docker-images.yml b/.github/workflows/build-docker-images.yml index 958d072..94d58d8 100644 --- a/.github/workflows/build-docker-images.yml +++ b/.github/workflows/build-docker-images.yml @@ -110,4 +110,4 @@ jobs: fi # use option --dir to use a subdirectory as a docker base dir - python3 "$GITHUB_WORKSPACE/.github/bin/docker_build" --dir "docker" "$@" + python3 "$GITHUB_WORKSPACE/.github/bin/docker_make" --dir "docker" "$@"