diff --git a/scripts/build-docker b/scripts/build-docker index a255dc2cb15..8dd88304d15 100755 --- a/scripts/build-docker +++ b/scripts/build-docker @@ -35,8 +35,10 @@ cp "${BINARYDIR}"/etcd "${BINARYDIR}"/etcdctl "${BINARYDIR}"/etcdutl "${IMAGEDIR cat ./"${DOCKERFILE}" > "${IMAGEDIR}"/Dockerfile if [ -z "$TAG" ]; then - docker build -t "gcr.io/etcd-development/etcd:${VERSION}" "${IMAGEDIR}" - docker build -t "quay.io/coreos/etcd:${VERSION}" "${IMAGEDIR}" + # Fix incorrect image "Architecture" using buildkit + # From https://stackoverflow.com/q/72144329/ + DOCKER_BUILDKIT=1 docker build -t "gcr.io/etcd-development/etcd:${VERSION}" "${IMAGEDIR}" + DOCKER_BUILDKIT=1 docker build -t "quay.io/coreos/etcd:${VERSION}" "${IMAGEDIR}" else docker build -t "${TAG}:${VERSION}" "${IMAGEDIR}" fi diff --git a/scripts/test_images.sh b/scripts/test_images.sh index f2d21b6dd28..00b23ac1893 100755 --- a/scripts/test_images.sh +++ b/scripts/test_images.sh @@ -82,3 +82,12 @@ fi echo "Succesfully tested etcd local image ${TAG}" +for TARGET_ARCH in "amd64" "arm64" "ppc64le" "s390x"; do + ARCH_TAG=v"${VERSION}"-"${TARGET_ARCH}" + IMG_ARCH=$(docker inspect --format '{{.Architecture}}' "${REPOSITARY}:${ARCH_TAG}") + if [ "${IMG_ARCH}" != "$TARGET_ARCH" ];then + echo "Incorrect docker image architecture" + exit 1 + fi + echo "Correct Architecture ${ARCH_TAG}" +done