We don't really need stuff from docker.py to do the build as we have everything we need with a direct call. We do need to tweak the dockerfiles so we can redo the UID/name mapping as the last step.
Signed-off-by: Alex Bennée <alex.ben...@linaro.org> --- tests/docker/Makefile.include | 38 ++++++++++--------- .../dockerfiles/debian-hexagon-cross.docker | 5 +++ .../dockerfiles/debian-toolchain.docker | 5 +++ 3 files changed, 31 insertions(+), 17 deletions(-) diff --git a/tests/docker/Makefile.include b/tests/docker/Makefile.include index c87f14477a..c34b3d1340 100644 --- a/tests/docker/Makefile.include +++ b/tests/docker/Makefile.include @@ -7,6 +7,8 @@ SPACE := $(NULL) # COMMA := , HOST_ARCH = $(if $(ARCH),$(ARCH),$(shell uname -m)) +USER = $(if $(NOUSER),,$(shell id -un)) +UID = $(if $(NOUSER),,$(shell id -u)) DOCKER_FILES_DIR := $(SRC_PATH)/tests/docker/dockerfiles ifeq ($(HOST_ARCH),x86_64) @@ -90,23 +92,25 @@ docker-image-debian-native: DOCKER_REGISTRY= # alpine has no adduser docker-image-alpine: NOUSER=1 -debian-toolchain-run = \ - $(if $(NOCACHE), \ - $(call quiet-command, \ - $(DOCKER_SCRIPT) build -t qemu/$1 -f $< \ - $(if $V,,--quiet) --no-cache \ - --registry $(DOCKER_REGISTRY) --extra-files \ - $(DOCKER_FILES_DIR)/$1.d/build-toolchain.sh, \ - "BUILD", $1), \ - $(call quiet-command, \ - $(DOCKER_SCRIPT) fetch $(if $V,,--quiet) \ - qemu/$1 $(DOCKER_REGISTRY), \ - "FETCH", $1) \ - $(call quiet-command, \ - $(DOCKER_SCRIPT) update $(if $V,,--quiet) \ - qemu/$1 \ - $(if $(NOUSER),,--add-current-user) \ - "PREPARE", $1)) +debian-toolchain-run = \ + $(call quiet-command, \ + $(RUNC) pull \ + $(if $V,,--quiet) \ + $(DOCKER_REGISTRY)/qemu/$1, \ + "FETCH", $1); \ + $(call quiet-command, \ + $(RUNC) build \ + $(if $V,,--quiet) \ + $(if $(NOCACHE),--no-cache) \ + $(if $(NOUSER),, \ + --build-arg USER=$(USER) \ + --build-arg UID=$(UID)) \ + -t qemu/$1 \ + -f - \ + $(DOCKER_FILES_DIR)/$1.d \ + < $<, \ + "BUILD", $1) + debian-toolchain = $(call debian-toolchain-run,$(patsubst docker-image-%,%,$1)) docker-image-debian-hexagon-cross: $(DOCKER_FILES_DIR)/debian-hexagon-cross.docker \ diff --git a/tests/docker/dockerfiles/debian-hexagon-cross.docker b/tests/docker/dockerfiles/debian-hexagon-cross.docker index 8d219bb81d..13fab3032a 100644 --- a/tests/docker/dockerfiles/debian-hexagon-cross.docker +++ b/tests/docker/dockerfiles/debian-hexagon-cross.docker @@ -48,3 +48,8 @@ RUN apt update && \ apt build-dep -yy --arch-only qemu COPY --from=0 /usr/local /usr/local ENV PATH $PATH:/usr/local/bin/ + +# As a final step configure the user (if env is defined) +ARG USER +ARG UID +RUN if [ "${USER}" ]; then id ${USER} 2>/dev/null || useradd -u ${UID} -U ${USER}; fi diff --git a/tests/docker/dockerfiles/debian-toolchain.docker b/tests/docker/dockerfiles/debian-toolchain.docker index d3d4d3344e..85e88f1ebb 100644 --- a/tests/docker/dockerfiles/debian-toolchain.docker +++ b/tests/docker/dockerfiles/debian-toolchain.docker @@ -35,3 +35,8 @@ RUN cd /root && ./build-toolchain.sh # then copying the built toolchain from stage 0. FROM docker.io/library/debian:bullseye-slim COPY --from=0 /usr/local /usr/local + +# As a final step configure the user (if env is defined) +ARG USER +ARG UID +RUN if [ "${USER}" ]; then id ${USER} 2>/dev/null || useradd -u ${UID} -U ${USER}; fi -- 2.34.1