This is an automated email from the ASF dual-hosted git repository. adoroszlai pushed a commit to branch jdk11 in repository https://gitbox.apache.org/repos/asf/ozone-docker-runner.git
commit 1b6bdb8bdba0022339765f48ad30ffd70a29d898 Author: Doroszlai, Attila <[email protected]> AuthorDate: Thu Nov 7 07:58:20 2024 +0100 HDDS-11632. Publish images to GitHub container registry (#30) (cherry picked from commit 797fc417b514777bbb8bdc42079da66c377facbc) --- .github/workflows/build-and-tag.yaml | 64 +++++++++++++++++++++++++++++++++ .github/workflows/build.yaml | 69 ++++++++++++++++++++++++++++++++---- 2 files changed, 126 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build-and-tag.yaml b/.github/workflows/build-and-tag.yaml new file mode 100644 index 0000000..199cc0b --- /dev/null +++ b/.github/workflows/build-and-tag.yaml @@ -0,0 +1,64 @@ +# Licensed to the Apache Software Foundation (ASF) under one or more +# contributor license agreements. See the NOTICE file distributed with +# this work for additional information regarding copyright ownership. +# The ASF licenses this file to You under the Apache License, Version 2.0 +# (the "License"); you may not use this file except in compliance with +# the License. You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +name: build-and-tag + +# This workflow builds (if necessary) and tags the Docker image. + +on: + push: + +permissions: + contents: read + packages: write + +jobs: + build: + uses: ./.github/workflows/build.yaml + + tag: + needs: build + if: ${{ github.ref_type == 'tag' }} + runs-on: ubuntu-latest + env: + IMAGE_ID: ${{ needs.build.outputs.image-id }} + steps: + - name: Generate tags + uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 + with: + images: | + ghcr.io/${{ github.repository_owner }}/ozone-runner + tags: | + type=ref,event=tag + flavor: | + latest=false + + - name: Pull image + run: | + docker pull "$IMAGE_ID" + + - name: Login to GitHub Container Registry + uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Apply tags to existing image + run: | + for tag in $DOCKER_METADATA_OUTPUT_TAGS; do + docker tag "$IMAGE_ID" "$tag" + docker push "$tag" + done diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index de51b61..02ae644 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -12,16 +12,71 @@ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. + name: build + +# This workflow builds the Docker image if it does not exists already. +# For non-PR runs, it also publishes the image to the registry, tagging it by the full SHA of the commit. + on: - - push - - pull_request + pull_request: + types: [opened, ready_for_review, synchronize] + workflow_call: + outputs: + image-id: + description: "Docker image ID in repo/owner/name:tag format" + value: ${{ jobs.build.outputs.image-id }} + +concurrency: + group: ${{ github.sha }} + cancel-in-progress: false + +permissions: + contents: read + packages: write + jobs: build: - name: build and deploy runs-on: ubuntu-latest + outputs: + image-id: ${{ steps.meta.outputs.tags }} steps: - - name: checkout source - uses: actions/checkout@v4 - - name: build image - run: DOCKER_BUILDKIT=1 docker build -t ghcr.io/$(echo $GITHUB_REPOSITORY | tr '[:upper:]' '[:lower:]' | sed 's/docker-//g') . + - name: Generate image ID + id: meta + uses: docker/metadata-action@8e5442c4ef9f78752691e2d8f8d19755c6f78e81 + with: + images: | + ghcr.io/${{ github.repository_owner }}/ozone-runner + tags: | + # keep single item + # any further tags should be added only in build-and-tag.yaml, not here + type=sha,prefix=,format=long + + - name: Check if image exists + id: pull + run: | + success=false + if docker pull "$DOCKER_METADATA_OUTPUT_TAGS"; then + success=true + fi + + echo "success=$success" >> $GITHUB_OUTPUT + + - name: Login to GitHub Container Registry + id: login + if: ${{ github.event_name != 'pull_request' && steps.pull.outputs.success == 'false' }} + uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Build and push image to GitHub Container Registry + id: build + if: ${{ steps.pull.outputs.success == 'false' }} + uses: docker/build-push-action@4f58ea79222b3b9dc2c8bbdd6debcef730109a75 + with: + platforms: linux/amd64 + push: ${{ github.event_name != 'pull_request' }} + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} --------------------------------------------------------------------- To unsubscribe, e-mail: [email protected] For additional commands, e-mail: [email protected]
