mirror of https://github.com/openwrt/docker.git
refactor build scripts
* add a functions.sh file containing functions used by all three container types, ImageBuilder, SDK and rootfs. * allow SDK branch tags for other branches than `master`. This allows testing of release SDK versions * Fix handling of special snapshot versions like `21.02-SNAPSHOT` Future commits will move `docker-download.sh` and `docker-build.sh` do `functions.sh`. Signed-off-by: Paul Spooren <mail@aparcar.org>pull/79/head
parent
8fd1339b33
commit
baf01edb31
|
@ -2,37 +2,37 @@
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
DOCKERFILE="${DOCKERFILE:-Dockerfile}"
|
|
||||||
# Copy Dockerfile inside build context to support older Docker versions
|
# Copy Dockerfile inside build context to support older Docker versions
|
||||||
# See https://github.com/docker/cli/pull/886
|
# See https://github.com/docker/cli/pull/886
|
||||||
cp "$DOCKERFILE" ./build/
|
cp "$DOCKERFILE" ./build/Dockerfile
|
||||||
TMP_IMAGE_NAME=$(tr -dc '[:lower:]' < /dev/urandom | fold -w 32 | head -n 1)
|
TMP_IMAGE_NAME=$(tr -dc '[:lower:]' </dev/urandom | fold -w 32 | head -n 1)
|
||||||
docker build -t "$TMP_IMAGE_NAME" -f "./build/$DOCKERFILE" ./build
|
docker build -t "$TMP_IMAGE_NAME" -f "./build/Dockerfile" ./build
|
||||||
|
|
||||||
for IMAGE in $DOCKER_IMAGE; do
|
for IMAGE in $DOCKER_IMAGE; do
|
||||||
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$TARGET-$VERSION"
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$TARGET-$VERSION"
|
||||||
|
|
||||||
if [ -n "$ARCH" ]; then
|
if [ -n "$ARCH" ]; then
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$ARCH-$VERSION"
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$ARCH-$VERSION"
|
||||||
fi
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$ARCH-$BRANCH"
|
||||||
|
|
||||||
if [ "$VERSION" == "snapshot" ]; then
|
if [ "$VERSION" == "snapshot" ]; then
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$TARGET-$BRANCH"
|
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$ARCH"
|
||||||
|
fi
|
||||||
if [ -n "$ARCH" ]; then
|
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$ARCH"
|
|
||||||
fi
|
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$TARGET"
|
|
||||||
|
|
||||||
if [ "$TARGET" == "x86-64" ]; then
|
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$BRANCH"
|
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:latest"
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$TARGET" == "x86-64" ]; then
|
if [ "$TARGET" == "x86-64" ]; then
|
||||||
docker tag "$IMAGE:$TARGET-$VERSION" "$IMAGE:$VERSION"
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$VERSION"
|
||||||
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$BRANCH"
|
||||||
|
|
||||||
|
if [ "$VERSION" == "snapshot" ]; then
|
||||||
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:latest"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
for TARGET_TAG in $TARGETS; do
|
||||||
|
TARGET_TAG=$(echo "$TARGET_TAG" | tr '/' '-')
|
||||||
|
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$TARGET_TAG-$VERSION"
|
||||||
|
done
|
||||||
done
|
done
|
||||||
|
|
||||||
docker rmi "$TMP_IMAGE_NAME"
|
docker rmi "$TMP_IMAGE_NAME"
|
||||||
|
|
|
@ -2,24 +2,12 @@
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
TARGET=$(echo "$CI_JOB_NAME" | cut -d _ -f 2-)
|
. ./functions.sh
|
||||||
export TARGET="${TARGET:-x86-64}"
|
|
||||||
export VERSION="${VERSION:-snapshot}"
|
|
||||||
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-imagebuilder}"
|
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-imagebuilder}"
|
||||||
export DOWNLOAD_FILE="openwrt-imagebuilder.*x86_64.tar.xz"
|
export DOWNLOAD_FILE="openwrt-imagebuilder.*x86_64.tar.xz"
|
||||||
|
|
||||||
if [ "$VERSION" = "snapshot" ]; then
|
export_variables
|
||||||
export BRANCH="master"
|
|
||||||
else
|
|
||||||
export BRANCH="openwrt-${VERSION%.*}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$VERSION" == "snapshot" ]; then
|
|
||||||
DOWNLOAD_PATH="snapshots/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
else
|
|
||||||
DOWNLOAD_PATH="releases/$VERSION/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
fi
|
|
||||||
export DOWNLOAD_PATH
|
|
||||||
|
|
||||||
./docker-download.sh || exit 1
|
./docker-download.sh || exit 1
|
||||||
./docker-build.sh || exit 1
|
./docker-build.sh || exit 1
|
||||||
|
|
|
@ -2,25 +2,13 @@
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
TARGET=$(echo "$CI_JOB_NAME" | cut -d _ -f 2-)
|
. ./functions.sh
|
||||||
export TARGET="${TARGET:-x86-64}"
|
|
||||||
export VERSION="${VERSION:-snapshot}"
|
|
||||||
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-rootfs}"
|
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-rootfs}"
|
||||||
export DOWNLOAD_FILE="openwrt-.*-rootfs.tar.gz"
|
export DOWNLOAD_FILE="openwrt-.*-rootfs.tar.gz"
|
||||||
export DOCKERFILE="Dockerfile.rootfs"
|
export DOCKERFILE="Dockerfile.rootfs"
|
||||||
|
|
||||||
if [ "$VERSION" = "snapshot" ]; then
|
export_variables
|
||||||
export BRANCH="master"
|
|
||||||
else
|
|
||||||
export BRANCH="openwrt-${VERSION%.*}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$VERSION" = "snapshot" ]; then
|
|
||||||
DOWNLOAD_PATH="snapshots/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
else
|
|
||||||
DOWNLOAD_PATH="releases/$VERSION/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
fi
|
|
||||||
export DOWNLOAD_PATH
|
|
||||||
|
|
||||||
./docker-download.sh || exit 1
|
./docker-download.sh || exit 1
|
||||||
|
|
||||||
|
|
|
@ -2,64 +2,18 @@
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
ARCH=$(echo "$CI_JOB_NAME" | cut -d _ -f 2-)
|
. ./functions.sh
|
||||||
# take the first supported target from TARGETS list
|
|
||||||
# shellcheck disable=SC2153
|
|
||||||
TARGET=$(echo "$TARGETS" | cut -d ' ' -f 1)
|
|
||||||
export TARGET="${TARGET:-x86-64}"
|
|
||||||
export ARCH="${ARCH:-x86_64}"
|
|
||||||
export VERSION="${VERSION:-snapshot}"
|
|
||||||
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-sdk}"
|
export DOCKER_IMAGE="${DOCKER_IMAGE:-openwrt-sdk}"
|
||||||
export DOWNLOAD_FILE="openwrt-sdk-.*.Linux-x86_64.tar.xz"
|
export DOWNLOAD_FILE="openwrt-sdk-.*.Linux-x86_64.tar.xz"
|
||||||
|
# take the first supported target from TARGETS list
|
||||||
|
# shellcheck disable=SC2153,SC2034
|
||||||
|
TARGET=$(echo "$TARGETS" | cut -d ' ' -f 1)
|
||||||
|
|
||||||
if [ "$VERSION" = "snapshot" ]; then
|
export_variables
|
||||||
export BRANCH="master"
|
|
||||||
else
|
|
||||||
export BRANCH="openwrt-${VERSION%.*}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$VERSION" == "snapshot" ]; then
|
|
||||||
DOWNLOAD_PATH="snapshots/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
else
|
|
||||||
DOWNLOAD_PATH="releases/$VERSION/targets/$(echo "$TARGET" | tr '-' '/')"
|
|
||||||
fi
|
|
||||||
export DOWNLOAD_PATH
|
|
||||||
|
|
||||||
./docker-download.sh || exit 1
|
./docker-download.sh || exit 1
|
||||||
|
|
||||||
echo "Using SDK from revision $(sed -ne 's/REVISION:=//p' ./build/include/version.mk)"
|
echo "Using SDK from revision $(sed -ne 's/REVISION:=//p' ./build/include/version.mk)"
|
||||||
|
|
||||||
DOCKERFILE="${DOCKERFILE:-Dockerfile}"
|
./docker-build.sh || exit 1
|
||||||
# Copy Dockerfile inside build context to support older Docker versions
|
|
||||||
# See https://github.com/docker/cli/pull/886
|
|
||||||
cp "$DOCKERFILE" ./build/
|
|
||||||
|
|
||||||
TMP_IMAGE_NAME=$(tr -dc '[:lower:]' < /dev/urandom | fold -w 32 | head -n 1)
|
|
||||||
docker build -t "$TMP_IMAGE_NAME" -f "./build/$DOCKERFILE" ./build
|
|
||||||
|
|
||||||
for IMAGE in $DOCKER_IMAGE; do
|
|
||||||
docker tag "$TMP_IMAGE_NAME" "$IMAGE:$ARCH-$VERSION"
|
|
||||||
|
|
||||||
if [ "$VERSION" == "snapshot" ]; then
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$ARCH-$BRANCH"
|
|
||||||
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$ARCH"
|
|
||||||
if [ "$ARCH" == "x86_64" ]; then
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$BRANCH"
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:latest"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$ARCH" == "x86_64" ]; then
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$VERSION"
|
|
||||||
fi
|
|
||||||
|
|
||||||
for TARGET_TAG in $TARGETS; do
|
|
||||||
TARGET_TAG=$(echo "$TARGET_TAG" | tr '/' '-')
|
|
||||||
docker tag "$IMAGE:$ARCH-$VERSION" "$IMAGE:$TARGET_TAG-$VERSION"
|
|
||||||
done
|
|
||||||
done
|
|
||||||
|
|
||||||
docker rmi "$TMP_IMAGE_NAME"
|
|
||||||
|
|
||||||
rm -rf ./build
|
|
||||||
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -ex
|
||||||
|
|
||||||
|
export_variables() {
|
||||||
|
ARCH=$(echo "$CI_JOB_NAME" | cut -d _ -f 2-)
|
||||||
|
export TARGET="${TARGET:-x86-64}"
|
||||||
|
export ARCH="${ARCH:-x86_64}"
|
||||||
|
export VERSION="${VERSION:-snapshot}"
|
||||||
|
export DOCKERFILE="${DOCKERFILE:-Dockerfile}"
|
||||||
|
|
||||||
|
case "$VERSION" in
|
||||||
|
snapshot)
|
||||||
|
export BRANCH="master"
|
||||||
|
;;
|
||||||
|
*-SNAPSHOT)
|
||||||
|
export BRANCH="openwrt-${VERSION%-*}"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
export BRANCH="openwrt-${VERSION%.*}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ "$VERSION" = "snapshot" ]; then
|
||||||
|
DOWNLOAD_PATH="snapshots/targets/$(echo "$TARGET" | tr '-' '/')"
|
||||||
|
else
|
||||||
|
DOWNLOAD_PATH="releases/$VERSION/targets/$(echo "$TARGET" | tr '-' '/')"
|
||||||
|
fi
|
||||||
|
export DOWNLOAD_PATH
|
||||||
|
}
|
Loading…
Reference in New Issue