From a8e98d9eb554afd4e4e659770bb15fd7ca009ef3 Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Sun, 28 Jul 2024 19:40:59 -0300 Subject: [PATCH] Do not use image tag without version (#5783) ## Which problem is this PR solving? - Resolves #5721 - The previous PR #5781 didn't quite work because we were still applying tags like `--tag docker.io/foo/bar` (without a version), which evidently leads Docker to treat them as `:latest`, which is exactly what we are trying to avoid for `main` branch ## Description of the changes - Remove usage of no-version tags `--tag docker.io/foo/bar` completely - Fix unit tests, make them stricter ## How was this change tested? - Unit tests Signed-off-by: Yuri Shkuro --- scripts/compute-tags.sh | 2 -- scripts/compute-tags.test.sh | 41 ++++++++++++++++++++++++++++-------- 2 files changed, 32 insertions(+), 11 deletions(-) diff --git a/scripts/compute-tags.sh b/scripts/compute-tags.sh index 077852d51d1..9c6038a7a92 100644 --- a/scripts/compute-tags.sh +++ b/scripts/compute-tags.sh @@ -28,8 +28,6 @@ tags() { IMAGE_TAGS="${IMAGE_TAGS}--tag docker.io/${1} --tag quay.io/${1}" } -tags "${BASE_BUILD_IMAGE}" - ## If we are on a release tag, let's extract the version number. ## The other possible values are 'main' or another branch name. if [[ $BRANCH =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then diff --git a/scripts/compute-tags.test.sh b/scripts/compute-tags.test.sh index 2fbd13815a3..3935106d391 100644 --- a/scripts/compute-tags.test.sh +++ b/scripts/compute-tags.test.sh @@ -5,6 +5,9 @@ SHUNIT2="${SHUNIT2:?'expecting SHUNIT2 env var pointing to a dir with https://github.com/kward/shunit2 clone'}" +# if running on MacOS, `brew install grep` and run with GREP=ggrep +GREP=${GREP:-grep} + # shellcheck disable=SC2086 computeTags="$(dirname $0)/compute-tags.sh" @@ -30,23 +33,44 @@ testRequireGithubSha() { assertContains "$err" "$err" 'expecting GITHUB_SHA env var' } +# out is global var which is populated for every output under test out="" + +scan_list() { + local target="$1" + echo "$out" | tr ' ' '\n' | $GREP -v '^--tag$' | $GREP -Po "^($target)"'$' +} + +expect_contains() { + local target="$1" + # shellcheck disable=SC2155 + local found=$(scan_list "$target") + assertContains "$found" "$target" +} + +expect_not_contains() { + local target="$1" + # shellcheck disable=SC2155 + local found=$(scan_list "$target") + assertNotContains "$found" "$target" +} + expect() { echo ' Actual:' "$out" while [ "$#" -gt 0 ]; do echo ' checking includes' "$1" - assertContains "actual [$out]" "$out" "--tag docker.io/$1" - assertContains "actual [$out]" "$out" "--tag quay.io/$1" + expect_contains "docker.io/$1" + expect_contains "quay.io/$1" shift done } -expectNot() { +expect_not() { echo ' Actual:' "$out" while [ "$#" -gt 0 ]; do echo ' checking excludes' "$1" - assertNotContains "actual [$out]" "$out" "--tag docker.io/$1" - assertNotContains "actual [$out]" "$out" "--tag quay.io/$1" + expect_not_contains "docker.io/$1" + expect_not_contains "quay.io/$1" shift done } @@ -54,29 +78,27 @@ expectNot() { testRandomBranch() { out=$(BRANCH=branch GITHUB_SHA=sha bash "$computeTags" foo/bar) expected=( - "foo/bar" "foo/bar:latest" "foo/bar-snapshot:sha" "foo/bar-snapshot:latest" ) expect "${expected[@]}" + expect_not "foo/bar" } testMainBranch() { out=$(BRANCH=main GITHUB_SHA=sha bash "$computeTags" foo/bar) expected=( - "foo/bar" "foo/bar-snapshot:sha" "foo/bar-snapshot:latest" ) expect "${expected[@]}" - expectNot "foo/bar:latest" + expect_not "foo/bar" "foo/bar:latest" } testSemVerBranch() { out=$(BRANCH=v1.2.3 GITHUB_SHA=sha bash "$computeTags" foo/bar) expected=( - "foo/bar" "foo/bar:latest" "foo/bar:1" "foo/bar:1.2" @@ -85,6 +107,7 @@ testSemVerBranch() { "foo/bar-snapshot:latest" ) expect "${expected[@]}" + expect_not "foo/bar" } # shellcheck disable=SC1091