From e1dfca6d923ae5a6fbce5f4d69abf2aa8375c11a Mon Sep 17 00:00:00 2001 From: Caleb Woodbine Date: Thu, 12 Oct 2023 13:35:27 +1300 Subject: [PATCH] chore: add tags to ko build + sha to docker build - add default tags to ko-build - add git-SHA to docker-build --- .github/workflows/reusable-docker-build.yml | 2 +- .github/workflows/reusable-ko-build.yml | 10 +++++++--- .github/workflows/test-reusable-docker-build.yml | 3 +++ 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/.github/workflows/reusable-docker-build.yml b/.github/workflows/reusable-docker-build.yml index da29357..4134af1 100644 --- a/.github/workflows/reusable-docker-build.yml +++ b/.github/workflows/reusable-docker-build.yml @@ -40,7 +40,7 @@ on: tags: required: false type: string - default: latest + default: latest,git-${{ github.sha }} description: | a comma separated list of tags to image tags. e.g: diff --git a/.github/workflows/reusable-ko-build.yml b/.github/workflows/reusable-ko-build.yml index 98496e8..1e81b12 100644 --- a/.github/workflows/reusable-ko-build.yml +++ b/.github/workflows/reusable-ko-build.yml @@ -104,9 +104,11 @@ jobs: name: collect job run info env: KO_DOCKER_REPO: ghcr.io/${{ github.repository }} + REGISTRY_OVERRIDE: ${{ inputs.registryOverride }} + TAGS: latest,git-${{ github.sha }} run: | - if [ -n "${{ inputs.registryOverride }}" ]; then - KO_DOCKER_REPO="${{ inputs.registryOverride }}" + if [ -n "$REGISTRY_OVERRIDE" ]; then + KO_DOCKER_REPO="$REGISTRY_OVERRIDE" fi echo "ko-docker-repo=${KO_DOCKER_REPO,,}" >> $GITHUB_OUTPUT if [ -n "${{ inputs.paths }}" ]; then @@ -115,6 +117,7 @@ jobs: PATHS="$(go list -json ./... | jq -r -s '.[] | select (.Name == "main") | .ImportPath' | xargs)" echo "paths="$PATHS"" >> $GITHUB_OUTPUT fi + echo "tags=$TAGS" >> $GITHUB_OUTPUT - uses: GeoNet/setup-crane@00c9e93efa4e1138c9a7a5c594acd6c75a2fbf0c # main with: version: ${{ env.VERSION_CRANE }} @@ -158,11 +161,12 @@ jobs: env: KO_DOCKER_REPO: ${{ steps.run-info.outputs.ko-docker-repo }} IMAGES_PATH: ${{ steps.run-info.outputs.paths }} + TAGS: ${{ steps.run-info.outputs.tags }} PUSH: ${{ inputs.push }} PLATFORMS: ${{ inputs.platforms }} run: | echo "NOTICE: using default base image $KO_DEFAULTBASEIMAGE" - IMAGES="$(ko build --platform=$PLATFORMS --push=$PUSH --base-import-paths $IMAGES_PATH)" + IMAGES="$(ko build --platform=$PLATFORMS --push=$PUSH --tags "$TAGS" --base-import-paths $IMAGES_PATH)" echo "images=$(echo $IMAGES | tr ' ' ',')" >> $GITHUB_OUTPUT - name: sign images and attest SBOM id: sign-images-and-attest-sbom diff --git a/.github/workflows/test-reusable-docker-build.yml b/.github/workflows/test-reusable-docker-build.yml index 3bfeaca..4ef4356 100644 --- a/.github/workflows/test-reusable-docker-build.yml +++ b/.github/workflows/test-reusable-docker-build.yml @@ -45,8 +45,11 @@ jobs: env: IMAGE: ${{ needs.t0-basic.outputs.image }} GH_TOKEN: ${{ github.token }} + SHA: ${{ github.sha }} run: | crane manifest $IMAGE + REPO="$(echo "$IMAGE" | cut -d'@' -f1)" + crane ls "$REPO" | grep -vE '\.(sbom|sig|att)$' | xargs | grep -E "^git-$SHA latest$" crane manifest $IMAGE | jq -r '.manifests[] | select(.annotations."vnd.docker.reference.type" != "attestation-manifest") | .platform.architecture' | xargs | grep -E '^amd64$' gh api -X DELETE /orgs/GeoNet/packages/container/actions%2Ftestimage-t0-basic || true t1-use-test: