From 6f1e1f12c95f111dd6453a14bf395bc64ace0843 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20D=C3=A9siles?= <1536672+jokesterfr@users.noreply.github.com> Date: Thu, 9 Jan 2025 10:31:51 +0100 Subject: [PATCH 1/8] fix(build): old base image --- .github/workflows/pull-request.yml | 14 ++++++++------ assets/alpine-base-install.sh | 7 +++++++ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index 4794bd9..832c6ed 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -106,13 +106,15 @@ jobs: env: DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} - docker_build_old_php: - name: "Docker build: PrestaShop with PHP 5.6" + docker_build_base: + name: "Docker build: PrestaShop with PHP ${{ matrix.php_version }} {{ matrix.os_version }}" runs-on: ubuntu-latest timeout-minutes: 45 strategy: fail-fast: true matrix: + php_version: + ["5.6", "7.0", "7.1", "7.2", "7.3", "7.4", "8.0", "8.1", "8.2", "8.3"] os_version: ["alpine", "debian"] needs: [docker_dry_build] steps: @@ -122,15 +124,15 @@ jobs: - name: Call the docker build chain run: ./build.sh env: - PS_VERSION: 1.6.1.24 - PHP_VERSION: 5.6 + PHP_VERSION: ${{ matrix.php_version }} OS_VERSION: ${{ matrix.os_version }} - REBUILD_BASE: "true" + TARGET_IMAGE: "prestashop/prestashop-flashlight:test" + BASE_ONLY: "true" - name: Test the image with a dry run run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' $DOCKER_IMAGE env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:1.6.1.24-${{ matrix.os_version }} + DOCKER_IMAGE: prestashop/prestashop-flashlight:test docker_build_debian: name: "Docker build: PS ${{ matrix.ps_version }} for debian" diff --git a/assets/alpine-base-install.sh b/assets/alpine-base-install.sh index a7636da..4d9fbc5 100755 --- a/assets/alpine-base-install.sh +++ b/assets/alpine-base-install.sh @@ -120,6 +120,13 @@ fi # Install Node.js (shipping yarn and npm) and pnpm if [ "0.0.0" != "$NODE_VERSION" ]; then apk --no-cache add -U python3 nodejs npm yarn + + # see https://stackoverflow.com/a/52196681 + NODE_MAJOR_VERSION=$(node -v | cut -d '.' -f1 | tr -d 'v') + if [ "$NODE_MAJOR_VERSION" -lt 14 ]; then + npm config set unsafe-perm true + fi + npm install -g pnpm@latest fi From c74b0229ed43ea0499222e9c2d8341deff3ef3f7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20D=C3=A9siles?= <1536672+jokesterfr@users.noreply.github.com> Date: Thu, 9 Jan 2025 12:15:41 +0100 Subject: [PATCH 2/8] Breaking change: input for base target images --- assets/hydrate.sh | 3 +- build.sh | 135 +++++++++++++++++++---------------- docker/flashlight.Dockerfile | 6 +- 3 files changed, 77 insertions(+), 67 deletions(-) diff --git a/assets/hydrate.sh b/assets/hydrate.sh index 2ee8cbd..e1de1e8 100755 --- a/assets/hydrate.sh +++ b/assets/hydrate.sh @@ -100,8 +100,9 @@ PS_OPT_DIR=/var/opt/prestashop mkdir -p "$PS_OPT_DIR" if echo "$PS_VERSION" | grep "^1.6" > /dev/null; then cp "$PS_FOLDER/config/settings.inc.php" "$PS_OPT_DIR/settings.inc.php" +elif [ -f "$PS_FOLDER/app/config/parameters.yml.dist" ]; then + cp "$PS_FOLDER/app/config/parameters.yml.dist" "$PS_OPT_DIR/parameters.yml" else - mkdir -p "$PS_OPT_DIR" cp "$PS_FOLDER/app/config/parameters.php" "$PS_OPT_DIR/parameters.php" fi diff --git a/build.sh b/build.sh index c987a0c..78aa62a 100755 --- a/build.sh +++ b/build.sh @@ -5,28 +5,20 @@ cd "$(dirname "$0")" # Available variables # ------------------- declare BASE_ONLY; # -- only build the base image (OS_FLAVOUR) without shipping PrestaShop -declare REBUILD_BASE; # -- force the rebuild of the base image +declare CUSTOM_LABELS; # -- A comma separated list of key=value pairs, for overriding official flashlight labels" declare DRY_RUN; # -- if used, won't really build the image. Useful to check tags compliance declare OS_FLAVOUR; # -- either "alpine" (default) or "debian" declare PHP_VERSION; # -- PHP version, defaults to recommended version for PrestaShop +declare PLATFORM; # -- alias for $TARGET_PLATFORM declare PS_VERSION; # -- PrestaShop version, defaults to latest declare PUSH; # -- set it to "true" if you want to push the resulting image +declare REBUILD_BASE; # -- force the rebuild of the base image declare SERVER_FLAVOUR; # -- either "nginx" (default) or "apache" -declare TARGET_IMAGE; # -- docker image name, defaults to "prestashop/prestashop-flashlight" -declare TARGET_PLATFORM; # -- a comma separated list of target platforms (defaults to "linux/amd64") -declare PLATFORM; # -- alias for $TARGET_PLATFORM +declare TARGET_IMAGE; # -- docker image name and tag, defaults to "$TARGET_IMAGE_NAME:$TARGET_IMAGE_TAG" +declare TARGET_IMAGE_NAME; # -- docker image name, defaults to "prestashop/prestashop-flashlight" +declare TARGET_IMAGE_TAG; # -- docker image tag, defaults to automatic tags based on the os flavour, php and prestashop versions +declare TARGET_PLATFORM; # -- a comma separated list of target platforms, defaults to "linux/amd64" declare ZIP_SOURCE; # -- the zip to unpack in flashlight -declare CUSTOM_LABELS; # -- A comma separated list of key=value pairs, for overriding official flashlight labels" -declare CUSTOM_BASE_IMAGE; # -- A name for overriding the base docker image. Usefull if you need to build the base to a custom repo - - -# Static configuration -# -------------------- -DEFAULT_BASE_DOCKER_IMAGE=prestashop/prestashop-flashlight -DEFAULT_OS="alpine"; -DEFAULT_PLATFORM=$(docker system info --format '{{.OSType}}/{{.Architecture}}') -DEFAULT_SERVER="nginx"; -GIT_SHA=$(git rev-parse HEAD) error() { echo "$(tput bold)$(tput setaf 1)${1:-Unknown error}$(tput sgr0)" @@ -37,36 +29,38 @@ help() { echo "$(tput bold)Usage:$(tput sgr0) $0 [options]" echo echo "$(tput bold)Options:$(tput sgr0)" - echo " --help Display this help message" - echo " --base-only Only build the base image (OS_FLAVOUR) without shipping PrestaShop" - echo " --dry-run Don't really build the image. Useful to check tags compliance" - echo " --os-flavour Either 'alpine' (default) or 'debian'" - echo " --php-version PHP version, defaults to recommended version for PrestaShop" - echo " --platform Alias for --target-platform" - echo " --ps-version PrestaShop version, defaults to latest" - echo " --push Push the resulting image to the registry" - echo " --rebuild-base Force the rebuild of the base image" - echo " --server-flavour Either 'nginx' (default) or 'apache'" - echo " --target-image Docker image name, defaults to 'prestashop/prestashop-flashlight'" - echo " --custom-labels A comma separated list of key=value pairs, for overriding official flashlight labels" - echo " --target-platform A comma separated list of target platforms (defaults to 'linux/amd64')" - echo " --zip-source The zip containing the PrestaShop release to build a docker image upon (defaults to PrestaShop source code)" - echo " --custom-base-image A name for overriding the base docker image. Usefull if you need to build the base to a custom repo" + echo " --help Display this help message" + echo " --base-only Only build the base image (OS_FLAVOUR) without shipping PrestaShop" + echo " --custom-labels A comma separated list of key=value pairs, for overriding official flashlight labels" + echo " --dry-run Don't really build the image. Useful to check tags compliance" + echo " --os-flavour Either 'alpine' (default) or 'debian'" + echo " --php-version PHP version, defaults to recommended version for PrestaShop" + echo " --platform Alias for --target-platform" + echo " --ps-version PrestaShop version, defaults to latest" + echo " --push Push the resulting image to the registry" + echo " --rebuild-base Force the rebuild of the base image" + echo " --server-flavour Either 'nginx' (default) or 'apache'" + echo " --target-image Docker image name and tag, defaults to TARGET_IMAGE_NAME:TARGET_IMAGE_TAG" + echo " --target-image-name Docker image name, defaults to \"prestashop/prestashop-flashlight\"" + echo " --target-image-tag Docker image tag, defaults to automatic tags based on the os flavour, php and prestashop versions" + echo " --target-platform A comma separated list of target platforms, defaults to 'linux/amd64'" + echo " --zip-source The zip containing the PrestaShop release to build a docker image upon (defaults to PrestaShop source code)" echo "" echo "$(tput bold)Environment variables:$(tput sgr0)" - echo " BASE_ONLY Only build the base image (OS_FLAVOUR) without shipping PrestaShop" - echo " DRY_RUN Don't really build the image. Useful to check tags compliance" - echo " OS_FLAVOUR Either 'alpine' (default) or 'debian'" - echo " PHP_VERSION PHP version, defaults to recommended version for PrestaShop" - echo " PS_VERSION PrestaShop version, defaults to latest" - echo " PUSH Set it to 'true' if you want to push the resulting image" - echo " REBUILD_BASE Force the rebuild of the base image" - echo " SERVER_FLAVOUR Either 'nginx' (default) or 'apache'" - echo " TARGET_IMAGE Docker image name, defaults to 'prestashop/prestashop-flashlight'" - echo " CUSTOM_LABELS A comma separated list of key=value pairs, for overriding official flashlight labels" - echo " TARGET_PLATFORM A comma separated list of target platforms (defaults to 'linux/amd64')" - echo " ZIP_SOURCE The zip containing the PrestaShop release to build a docker image upon (defaults to PrestaShop source code)" - echo " CUSTOM_BASE_IMAGE A name for overriding the base docker image. Usefull if you need to build the base to a custom repo" + echo " BASE_ONLY Only build the base image (OS_FLAVOUR) without shipping PrestaShop" + echo " CUSTOM_LABELS A comma separated list of key=value pairs, for overriding official flashlight labels" + echo " DRY_RUN Don't really build the image. Useful to check tags compliance" + echo " OS_FLAVOUR Either 'alpine' (default) or 'debian'" + echo " PHP_VERSION PHP version, defaults to recommended version for PrestaShop" + echo " PS_VERSION PrestaShop version, defaults to latest" + echo " PUSH Set it to 'true' if you want to push the resulting image" + echo " REBUILD_BASE Force the rebuild of the base image" + echo " SERVER_FLAVOUR Either 'nginx' (default) or 'apache'" + echo " TARGET_IMAGE Docker image name, defaults to TARGET_IMAGE_NAME:TARGET_IMAGE_TAG" + echo " TARGET_IMAGE_NAME Docker image name, defaults to \"prestashop/prestashop-flashlight\"" + echo " TARGET_IMAGE_TAG Docker image tag, defaults to automatic tags based on the os flavour, php and prestashop versions" + echo " TARGET_PLATFORM A comma separated list of target platforms, defaults to 'linux/amd64'" + echo " ZIP_SOURCE The zip containing the PrestaShop release to build a docker image upon (defaults to PrestaShop source code)" } # Parsing input arguments @@ -75,6 +69,7 @@ while [ "$#" -gt 0 ]; do case "$1" in --help) help; exit 0;; --base-only) BASE_ONLY=true; shift;; + --custom-labels) CUSTOM_LABELS="$2"; shift; shift;; --dry-run) DRY_RUN=true; shift;; --os-flavour) OS_FLAVOUR="$2"; shift; shift;; --php-version) PHP_VERSION="$2"; shift; shift;; @@ -84,21 +79,24 @@ while [ "$#" -gt 0 ]; do --rebuild-base) REBUILD_BASE=true; shift;; --server-flavour) SERVER_FLAVOUR="$2"; shift; shift;; --target-image) TARGET_IMAGE="$2"; shift; shift;; - --custom-labels) CUSTOM_LABELS="$2"; shift; shift;; + --target-image-name) TARGET_IMAGE_NAME="$2"; shift; shift;; + --target-image-tag) TARGET_IMAGE_TAG="$2"; shift; shift;; --zip-source) ZIP_SOURCE="$2"; shift; shift;; - --custom-base-image) CUSTOM_BASE_IMAGE="$2"; shift; shift;; *) error "Unknown option: $1" 2;; esac done # Default configuration # --------------------- -PUSH=${PUSH:-false} BASE_ONLY=${BASE_ONLY:-false} -REBUILD_BASE=${REBUILD_BASE:-$BASE_ONLY} +DEFAULT_OS="alpine"; +DEFAULT_PLATFORM=$(docker system info --format '{{.OSType}}/{{.Architecture}}') +DEFAULT_SERVER="nginx"; DRY_RUN=${DRY_RUN:-false} +GIT_SHA=$(git rev-parse HEAD) +PUSH=${PUSH:-false} +REBUILD_BASE=${REBUILD_BASE:-$BASE_ONLY} TARGET_PLATFORM="${TARGET_PLATFORM:-${PLATFORM:-$DEFAULT_PLATFORM}}" -BASE_DOCKER_IMAGE="${CUSTOM_BASE_IMAGE:-${DEFAULT_BASE_DOCKER_IMAGE}}" LABELS=( "--label" "org.opencontainers.image.title=\"Prestashop Flashlight\"" "--label" "org.opencontainers.image.description=\"PrestaShop Flashlight testing utility\"" @@ -108,6 +106,13 @@ LABELS=( "--label" "org.opencontainers.image.created=\"$(date -u +"%Y-%m-%dT%H:%M:%S.%3NZ")\"" ); +TARGET_IMAGE_NAME=${TARGET_IMAGE_NAME:-prestashop/prestashop-flashlight} + +# if the tag is defined there won't be auto +if [ -n "$TARGET_IMAGE_TAG" ]; then + TARGET_IMAGE=${TARGET_IMAGE_NAME}:${TARGET_IMAGE_TAG} +fi + get_latest_prestashop_version() { curl --silent --show-error --fail --location --request GET \ 'https://api.github.com/repos/prestashop/prestashop/releases/latest' | jq -r '.tag_name' @@ -181,26 +186,26 @@ get_target_images() { declare RES; if [ "$PS_VERSION" == "nightly" ]; then if [ "$OS_FLAVOUR" = "$DEFAULT_OS" ]; then - RES="-t ${BASE_DOCKER_IMAGE}:nightly-${SERVER_FLAVOUR}"; + RES="-t ${TARGET_IMAGE_NAME}:nightly-${SERVER_FLAVOUR}"; else - RES="-t ${BASE_DOCKER_IMAGE}:nightly-${OS_FLAVOUR}-${SERVER_FLAVOUR}"; + RES="-t ${TARGET_IMAGE_NAME}:nightly-${OS_FLAVOUR}-${SERVER_FLAVOUR}"; fi else if [ "$PS_VERSION" = "$(get_latest_prestashop_version)" ] \ && [ "$OS_FLAVOUR" = "$DEFAULT_OS" ] \ && [ "$PHP_VERSION" = "$(get_recommended_php_version "$PS_VERSION")" ] \ && [ "$SERVER_FLAVOUR" = "$DEFAULT_SERVER" ]; then - RES="-t ${BASE_DOCKER_IMAGE}:latest"; + RES="-t ${TARGET_IMAGE_NAME}:latest"; fi if [ "$OS_FLAVOUR" = "$DEFAULT_OS" ]; then - RES="${RES} -t ${BASE_DOCKER_IMAGE}:${PS_VERSION}-${PHP_VERSION}-${SERVER_FLAVOUR}"; + RES="${RES} -t ${TARGET_IMAGE_NAME}:${PS_VERSION}-${PHP_VERSION}-${SERVER_FLAVOUR}"; if [ "$PHP_VERSION" = "$(get_recommended_php_version "$PS_VERSION")" ]; then - RES="${RES} -t ${BASE_DOCKER_IMAGE}:${PS_VERSION}-${SERVER_FLAVOUR}"; - RES="${RES} -t ${BASE_DOCKER_IMAGE}:php-${PHP_VERSION}-${SERVER_FLAVOUR}"; + RES="${RES} -t ${TARGET_IMAGE_NAME}:${PS_VERSION}-${SERVER_FLAVOUR}"; + RES="${RES} -t ${TARGET_IMAGE_NAME}:php-${PHP_VERSION}-${SERVER_FLAVOUR}"; fi fi - RES="${RES} -t ${BASE_DOCKER_IMAGE}:${PS_VERSION}-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}"; - RES="${RES} -t ${BASE_DOCKER_IMAGE}:${PS_VERSION}-${OS_FLAVOUR}-${SERVER_FLAVOUR}"; + RES="${RES} -t ${TARGET_IMAGE_NAME}:${PS_VERSION}-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}"; + RES="${RES} -t ${TARGET_IMAGE_NAME}:${PS_VERSION}-${OS_FLAVOUR}-${SERVER_FLAVOUR}"; fi echo "$RES"; } @@ -219,10 +224,15 @@ NODE_VERSION=$(get_recommended_nodejs_version "$PS_VERSION"); if [ "$PHP_BASE_IMAGE" == "null" ]; then error "Could not find a PHP flavour for $OS_FLAVOUR + $SERVER_FLAVOUR + $PHP_VERSION" 2; fi + if [ -z "${TARGET_IMAGE:+x}" ]; then read -ra TARGET_IMAGES <<<"$(get_target_images "$PHP_BASE_IMAGE" "$PS_VERSION" "$PHP_VERSION" "$OS_FLAVOUR")" + read -ra TARGET_BASE_IMAGES <<<"-t $TARGET_IMAGE_NAME:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}" + BASE_DOCKER_IMAGE="$TARGET_IMAGE_NAME:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}" else read -ra TARGET_IMAGES <<<"-t $TARGET_IMAGE" + read -ra TARGET_BASE_IMAGES <<<"-t $TARGET_IMAGE" + BASE_DOCKER_IMAGE="$TARGET_IMAGE" fi # If ZIP_SOURCE is not defined, set it based on PS_VERSION @@ -247,14 +257,14 @@ fi # Build the docker image # ---------------------- -CACHE_IMAGE=$BASE_DOCKER_IMAGE:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR} if [ "$DRY_RUN" == "true" ]; then docker() { echo docker "$@" } fi -docker pull "$CACHE_IMAGE" 2> /dev/null || REBUILD_BASE='true'; +# acts as a cache if available +docker pull "$BASE_DOCKER_IMAGE" 2> /dev/null || REBUILD_BASE='true'; if [ "$REBUILD_BASE" == "true" ]; then echo "building base for $PHP_BASE_IMAGE $SERVER_FLAVOUR ($TARGET_PLATFORM)" @@ -262,7 +272,7 @@ if [ "$REBUILD_BASE" == "true" ]; then --progress=plain \ --file "./docker/$OS_FLAVOUR-base.Dockerfile" \ --platform "$TARGET_PLATFORM" \ - --cache-from type=registry,ref="$CACHE_IMAGE" \ + --cache-from type=registry,ref="$BASE_DOCKER_IMAGE" \ --cache-to type=inline \ --build-arg PHP_BASE_IMAGE="$PHP_BASE_IMAGE" \ --build-arg PHP_VERSION="$PHP_VERSION" \ @@ -270,7 +280,7 @@ if [ "$REBUILD_BASE" == "true" ]; then --build-arg GIT_SHA="$GIT_SHA" \ --build-arg SERVER_FLAVOUR="$SERVER_FLAVOUR" \ "${LABELS[@]}" \ - --tag "$BASE_DOCKER_IMAGE:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}" \ + "${TARGET_BASE_IMAGES[@]}" \ "$([ "${PUSH}" == "true" ] && echo "--push" || echo "--load")" \ . fi @@ -280,15 +290,16 @@ if [ "$BASE_ONLY" == "false" ]; then --progress=plain \ --file "./docker/flashlight.Dockerfile" \ --platform "$TARGET_PLATFORM" \ - --cache-from type=registry,ref="$CACHE_IMAGE" \ + --cache-from type=registry,ref="$BASE_DOCKER_IMAGE" \ --cache-to type=inline \ + --build-arg BASE_DOCKER_IMAGE="$BASE_DOCKER_IMAGE" \ --build-arg PHP_BASE_IMAGE="$PHP_BASE_IMAGE" \ --build-arg PS_VERSION="$PS_VERSION" \ --build-arg PHP_VERSION="$PHP_VERSION" \ --build-arg GIT_SHA="$GIT_SHA" \ --build-arg ZIP_SOURCE="$ZIP_SOURCE" \ --build-arg SERVER_FLAVOUR="$SERVER_FLAVOUR" \ - --build-arg BASE_DOCKER_IMAGE="$BASE_DOCKER_IMAGE" \ + --build-arg TARGET_IMAGE_NAME="$TARGET_IMAGE_NAME" \ "${LABELS[@]}" \ "${TARGET_IMAGES[@]}" \ "$([ "${PUSH}" == "true" ] && echo "--push" || echo "--load")" \ diff --git a/docker/flashlight.Dockerfile b/docker/flashlight.Dockerfile index e544ff9..62bce1a 100644 --- a/docker/flashlight.Dockerfile +++ b/docker/flashlight.Dockerfile @@ -2,9 +2,8 @@ # Flashlight install and dump SQL # -------------------------------- ARG BASE_DOCKER_IMAGE -ARG PHP_BASE_IMAGE ARG SERVER_FLAVOUR -FROM ${BASE_DOCKER_IMAGE}:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR} AS build-and-dump +FROM ${BASE_DOCKER_IMAGE} AS build-and-dump ARG PS_VERSION ARG PHP_VERSION ARG GIT_SHA @@ -42,9 +41,8 @@ RUN sh /hydrate.sh # Flashlight final image # ----------------------- ARG BASE_DOCKER_IMAGE -ARG PHP_BASE_IMAGE ARG SERVER_FLAVOUR -FROM ${BASE_DOCKER_IMAGE}:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR} AS prestashop-flashlight +FROM ${BASE_DOCKER_IMAGE} AS prestashop-flashlight ARG PS_VERSION ARG PHP_VERSION ARG PHP_BASE_IMAGE From 88101349189ffdc6920001c963fbcd8ff0104035 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20D=C3=A9siles?= <1536672+jokesterfr@users.noreply.github.com> Date: Thu, 9 Jan 2025 12:20:36 +0100 Subject: [PATCH 3/8] Slight simplification --- build.sh | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/build.sh b/build.sh index 78aa62a..fff7ff8 100755 --- a/build.sh +++ b/build.sh @@ -227,11 +227,9 @@ fi if [ -z "${TARGET_IMAGE:+x}" ]; then read -ra TARGET_IMAGES <<<"$(get_target_images "$PHP_BASE_IMAGE" "$PS_VERSION" "$PHP_VERSION" "$OS_FLAVOUR")" - read -ra TARGET_BASE_IMAGES <<<"-t $TARGET_IMAGE_NAME:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}" BASE_DOCKER_IMAGE="$TARGET_IMAGE_NAME:base-${PHP_BASE_IMAGE}-${SERVER_FLAVOUR}" else read -ra TARGET_IMAGES <<<"-t $TARGET_IMAGE" - read -ra TARGET_BASE_IMAGES <<<"-t $TARGET_IMAGE" BASE_DOCKER_IMAGE="$TARGET_IMAGE" fi @@ -280,7 +278,7 @@ if [ "$REBUILD_BASE" == "true" ]; then --build-arg GIT_SHA="$GIT_SHA" \ --build-arg SERVER_FLAVOUR="$SERVER_FLAVOUR" \ "${LABELS[@]}" \ - "${TARGET_BASE_IMAGES[@]}" \ + -t "$BASE_DOCKER_IMAGE" \ "$([ "${PUSH}" == "true" ] && echo "--push" || echo "--load")" \ . fi From a268e323ba6b26a58f6c7b27f06e37930f472f4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20D=C3=A9siles?= <1536672+jokesterfr@users.noreply.github.com> Date: Thu, 9 Jan 2025 12:25:43 +0100 Subject: [PATCH 4/8] CI definition simplification --- .github/workflows/pull-request.yml | 36 +++++++++--------------------- 1 file changed, 11 insertions(+), 25 deletions(-) diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index 832c6ed..112010f 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -80,31 +80,22 @@ jobs: env: PS_VERSION: ${{ matrix.ps_version }} REBUILD_BASE: "true" + TARGET_IMAGE: "flashlight:${{ matrix.ps_version }}" - name: Test the image with a dry run - run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' $DOCKER_IMAGE - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} + run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' flashlight:${{ matrix.ps_version }} - name: Test the image tooling(composer) - run: docker run --env PS_DOMAIN='localhost:80' --entrypoint composer $DOCKER_IMAGE --version - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} + run: docker run --env PS_DOMAIN='localhost:80' --entrypoint composer flashlight:${{ matrix.ps_version }} --version - name: Test the image tooling(phpunit) - run: docker run --env PS_DOMAIN='localhost:80' --entrypoint phpunit $DOCKER_IMAGE --version - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} + run: docker run --env PS_DOMAIN='localhost:80' --entrypoint phpunit flashlight:${{ matrix.ps_version }} --version - name: Test the image tooling(phpstan) - run: docker run --env PS_DOMAIN='localhost:80' --entrypoint phpstan $DOCKER_IMAGE --version - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} + run: docker run --env PS_DOMAIN='localhost:80' --entrypoint phpstan flashlight:${{ matrix.ps_version }} --version - name: Test the image tooling(xdebug) - run: docker run --env PS_DOMAIN='localhost:80' --entrypoint bash $DOCKER_IMAGE -c 'php -m -c | grep xdebug' - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }} + run: docker run --env PS_DOMAIN='localhost:80' --entrypoint bash flashlight:${{ matrix.ps_version }} -c 'php -m -c | grep xdebug' docker_build_base: name: "Docker build: PrestaShop with PHP ${{ matrix.php_version }} {{ matrix.os_version }}" @@ -126,13 +117,11 @@ jobs: env: PHP_VERSION: ${{ matrix.php_version }} OS_VERSION: ${{ matrix.os_version }} - TARGET_IMAGE: "prestashop/prestashop-flashlight:test" + TARGET_IMAGE: "flashlight:test" BASE_ONLY: "true" - name: Test the image with a dry run - run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' $DOCKER_IMAGE - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:test + run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' flashlight:test docker_build_debian: name: "Docker build: PS ${{ matrix.ps_version }} for debian" @@ -152,17 +141,14 @@ jobs: env: OS_FLAVOUR: "debian" PS_VERSION: ${{ matrix.ps_version }} + TARGET_IMAGE: "flashlight:${{ matrix.ps_version }}-debian" REBUILD_BASE: "true" - name: Test the image with a dry run - run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' $DOCKER_IMAGE - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }}-debian + run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' flashlight:${{ matrix.ps_version }}-debian - name: The image has a PrestaShop console CLI - run: docker run --env PS_DOMAIN='localhost:80' --entrypoint /bin/ls $DOCKER_IMAGE bin/console - env: - DOCKER_IMAGE: prestashop/prestashop-flashlight:${{ matrix.ps_version }}-debian + run: docker run --env PS_DOMAIN='localhost:80' --entrypoint /bin/ls flashlight:${{ matrix.ps_version }}-debian bin/console docker_build_nightly: name: "Docker build: PS nightly" From 3b1ba2018f2ddde477ad167468de09f15d31fb0e Mon Sep 17 00:00:00 2001 From: Alexandre Lematre Date: Tue, 21 Jan 2025 14:59:15 +0100 Subject: [PATCH 5/8] Fix 7.0 build --- assets/alpine-base-install.sh | 20 +++++++++++++++++--- docker/alpine-base.Dockerfile | 2 +- php-flavours.json | 2 +- 3 files changed, 19 insertions(+), 5 deletions(-) diff --git a/assets/alpine-base-install.sh b/assets/alpine-base-install.sh index 4d9fbc5..bc48d5b 100755 --- a/assets/alpine-base-install.sh +++ b/assets/alpine-base-install.sh @@ -4,11 +4,17 @@ set -eu # Install base tools, PHP requirements and dev-tools packages="bash less vim geoip git tzdata zip curl jq autoconf findutils \ ca-certificates \ - php-common php-iconv php-gd mariadb-client sudo libjpeg libxml2 \ + mariadb-client sudo libjpeg libxml2 \ build-base linux-headers freetype-dev zlib-dev libjpeg-turbo-dev \ libpng-dev oniguruma-dev libzip-dev icu-dev libmcrypt-dev libxml2-dev \ openssh-client libcap shadow" +if [ "$(printf '%s' "$PHP_VERSION" | cut -c 1)" = "7" ]; then + packages="$packages php7-common php7-iconv php7-gd" +else + packages="$packages php-common php-iconv php-gd" +fi + if [ "$SERVER_FLAVOUR" = "nginx" ]; then packages="$packages nginx nginx-mod-http-headers-more nginx-mod-http-geoip nginx-mod-stream nginx-mod-stream-geoip" else @@ -99,7 +105,7 @@ fi # Install phpstan PHPSTAN_VERSION=$(jq -r '."'"${PHP_SHORT_VERSION}"'".phpstan' < /tmp/php-flavours.json) if [ "$PHPSTAN_VERSION" != "null" ]; then - wget -q -O /usr/bin/phpstan "https://github.com/phpstan/phpstan/raw/${PHPSTAN_VERSION}/phpstan.phar" + wget -q -O /usr/bin/phpstan "https://github.com/phpstan/phpstan/releases/download/${PHPSTAN_VERSION}/phpstan.phar" chmod a+x /usr/bin/phpstan fi @@ -119,7 +125,15 @@ fi # Install Node.js (shipping yarn and npm) and pnpm if [ "0.0.0" != "$NODE_VERSION" ]; then - apk --no-cache add -U python3 nodejs npm yarn + packagesForNode=python3 + if [ "$(printf '%s' "$PHP_VERSION" | cut -c 1)" = "7" ]; then + packagesForNode="$packagesForNode nodejs-npm yarn" + else + packagesForNode="$packagesForNode nodejs npm yarn" + fi + # shellcheck disable=SC2086 + set -- $packagesForNode + apk --no-cache add -U "$@" # see https://stackoverflow.com/a/52196681 NODE_MAJOR_VERSION=$(node -v | cut -d '.' -f1 | tr -d 'v') diff --git a/docker/alpine-base.Dockerfile b/docker/alpine-base.Dockerfile index b6e53be..05c58bc 100644 --- a/docker/alpine-base.Dockerfile +++ b/docker/alpine-base.Dockerfile @@ -41,6 +41,6 @@ RUN version="$(php -r "echo PHP_MAJOR_VERSION.PHP_MINOR_VERSION;")" \ && rm -rf /tmp/blackfire /tmp/blackfire-probe.tar.gz # Install and configure MariaDB -RUN adduser --system mysql \ +RUN adduser -D -s /sbin/nologin mysql \ && apk --no-cache add -U --no-commit-hooks --no-scripts mariadb; COPY ./assets/mariadb-server.cnf /etc/my.cnf.d/mariadb-server.cnf diff --git a/php-flavours.json b/php-flavours.json index f0f1a55..e3a5748 100644 --- a/php-flavours.json +++ b/php-flavours.json @@ -8,7 +8,7 @@ "debian": "7.0-fpm-jessie", "phpunit": "6.5.14", "php_cs_fixer": "v2.19.3", - "phpstan": "0.9.3", + "phpstan": "0.9.2", "xdebug": "2.7.2" }, "7.1": { From 30c6d6f961eaeab7925aa98f146db158bebcddb0 Mon Sep 17 00:00:00 2001 From: Alexandre Lematre Date: Tue, 21 Jan 2025 15:35:07 +0100 Subject: [PATCH 6/8] Narrow php 7 fixes --- assets/alpine-base-install.sh | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/assets/alpine-base-install.sh b/assets/alpine-base-install.sh index bc48d5b..936489e 100755 --- a/assets/alpine-base-install.sh +++ b/assets/alpine-base-install.sh @@ -9,7 +9,7 @@ packages="bash less vim geoip git tzdata zip curl jq autoconf findutils \ libpng-dev oniguruma-dev libzip-dev icu-dev libmcrypt-dev libxml2-dev \ openssh-client libcap shadow" -if [ "$(printf '%s' "$PHP_VERSION" | cut -c 1)" = "7" ]; then +if [ "$PHP_VERSION" = "7.0" ] || [ "$PHP_VERSION" = "7.1" ] || [ "$PHP_VERSION" = "7.2" ]; then packages="$packages php7-common php7-iconv php7-gd" else packages="$packages php-common php-iconv php-gd" @@ -105,7 +105,13 @@ fi # Install phpstan PHPSTAN_VERSION=$(jq -r '."'"${PHP_SHORT_VERSION}"'".phpstan' < /tmp/php-flavours.json) if [ "$PHPSTAN_VERSION" != "null" ]; then - wget -q -O /usr/bin/phpstan "https://github.com/phpstan/phpstan/releases/download/${PHPSTAN_VERSION}/phpstan.phar" + + PHP_STAN_DL_URL="https://github.com/phpstan/phpstan/releases/download/${PHPSTAN_VERSION}/phpstan.phar" + if [ "$PHPSTAN_VERSION" = "HEAD" ]; then + PHP_STAN_DL_URL="https://github.com/phpstan/phpstan/raw/HEAD/phpstan.phar" + fi + + wget -q -O /usr/bin/phpstan "$PHP_STAN_DL_URL" chmod a+x /usr/bin/phpstan fi @@ -126,7 +132,7 @@ fi # Install Node.js (shipping yarn and npm) and pnpm if [ "0.0.0" != "$NODE_VERSION" ]; then packagesForNode=python3 - if [ "$(printf '%s' "$PHP_VERSION" | cut -c 1)" = "7" ]; then + if [ "$PHP_VERSION" = "7.0" ] || [ "$PHP_VERSION" = "7.1" ] || [ "$PHP_VERSION" = "7.2" ]; then packagesForNode="$packagesForNode nodejs-npm yarn" else packagesForNode="$packagesForNode nodejs npm yarn" From 6181ba6a2ec890744897258cf51a7f4aa1a3f47b Mon Sep 17 00:00:00 2001 From: Alexandre Lematre Date: Wed, 22 Jan 2025 10:58:29 +0100 Subject: [PATCH 7/8] Fix dry run base build --- .github/workflows/pull-request.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index 112010f..27f3c95 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -116,12 +116,12 @@ jobs: run: ./build.sh env: PHP_VERSION: ${{ matrix.php_version }} - OS_VERSION: ${{ matrix.os_version }} + OS_FLAVOUR: ${{ matrix.os_version }} TARGET_IMAGE: "flashlight:test" BASE_ONLY: "true" - name: Test the image with a dry run - run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' flashlight:test + run: docker run --env PS_DOMAIN='localhost:80' --env DRY_RUN='true' --user www-data flashlight:test docker_build_debian: name: "Docker build: PS ${{ matrix.ps_version }} for debian" From 949edf7422de9ccc97201de8e7f71b21431fc609 Mon Sep 17 00:00:00 2001 From: Alexandre Lematre Date: Wed, 22 Jan 2025 14:18:54 +0100 Subject: [PATCH 8/8] Fix unbound VERSION_CODENAME variable --- assets/debian-base-install.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/assets/debian-base-install.sh b/assets/debian-base-install.sh index fbc7870..a298c0b 100755 --- a/assets/debian-base-install.sh +++ b/assets/debian-base-install.sh @@ -13,6 +13,7 @@ rm -rf /usr/share/doc \ /usr/share/locale # Get debian version and codename +VERSION_CODENAME="" # shellcheck disable=SC1091 . /etc/os-release if [ "$VERSION_ID" = 9 ]; then