Merge pull request #19275 from Homebrew/docker-image-arm64

workflows/docker: build and publish ARM64 Docker images
This commit is contained in:
Mike McQuaid 2025-03-13 10:05:24 +00:00 committed by GitHub
commit b16a2e905c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -18,14 +18,22 @@ defaults:
shell: bash -xeuo pipefail {0} shell: bash -xeuo pipefail {0}
jobs: jobs:
ubuntu: build:
if: github.repository_owner == 'Homebrew' if: github.repository_owner == 'Homebrew'
name: docker (Ubuntu ${{ matrix.version }}) name: docker (${{ matrix.arch }} Ubuntu ${{ matrix.version }})
runs-on: ubuntu-latest runs-on: ${{ matrix.arch == 'arm64' && 'ubuntu-24.04-arm' || 'ubuntu-latest' }}
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
version: ["18.04", "20.04", "22.04", "24.04"] version: ["18.04", "20.04", "22.04", "24.04"]
arch: ["x86_64", "arm64"]
exclude:
- version: "18.04"
arch: "arm64"
- arch: ${{ github.event_name == 'release' && 'arm64' }}
outputs:
tags: ${{ steps.attributes.outputs.tags }}
push: ${{ steps.attributes.outputs.push }}
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
@ -122,6 +130,8 @@ jobs:
labels: ${{ steps.attributes.outputs.labels }} labels: ${{ steps.attributes.outputs.labels }}
- name: Run brew test-bot --only-setup - name: Run brew test-bot --only-setup
# TODO: Remove this conditional when `brew doctor` no longer throws an error on ARM64 Linux.
if: matrix.arch == 'x86_64'
run: docker run --rm brew brew test-bot --only-setup run: docker run --rm brew brew test-bot --only-setup
- name: Log in to GitHub Packages (BrewTestBot) - name: Log in to GitHub Packages (BrewTestBot)
@ -132,21 +142,81 @@ jobs:
username: BrewTestBot username: BrewTestBot
password: ${{ secrets.HOMEBREW_BREW_GITHUB_PACKAGES_TOKEN }} password: ${{ secrets.HOMEBREW_BREW_GITHUB_PACKAGES_TOKEN }}
- name: Log in to Docker Hub - name: Deploy the Docker image by digest
id: digest
if: steps.attributes.outputs.push == 'true' if: steps.attributes.outputs.push == 'true'
uses: docker/build-push-action@471d1dc4e07e5cdedd4c2171150001c434f0b7a4 # v6.15.0
with:
context: .
cache-from: type=registry,ref=ghcr.io/homebrew/ubuntu${{ matrix.version }}:cache
cache-to: type=registry,ref=ghcr.io/homebrew/ubuntu${{ matrix.version }}:cache,mode=max
build-args: version=${{ matrix.version }}
labels: ${{ steps.attributes.outputs.labels }}
outputs: type=image,name=ghcr.io/homebrew/ubuntu${{ matrix.version }},name-canonical=true,push=true,push-by-digest=true
- name: Export the Docker image digest
if: steps.attributes.outputs.push == 'true'
run: |
mkdir -p "${RUNNER_TEMP}"/digests
echo "${DIGEST#sha256:}" >"${RUNNER_TEMP}/digests/${VERSION}-${ARCH}"
env:
DIGEST: ${{ steps.digest.outputs.digest }}
VERSION: ${{ matrix.version }}
ARCH: ${{ matrix.arch }}
- name: Upload the Docker image digest
if: steps.attributes.outputs.push == 'true'
uses: actions/upload-artifact@65c4c4a1ddee5b72f698fdd19549f0f0fb45cf08 # v4.6.0
with:
name: digest-${{ matrix.version }}-${{ matrix.arch }}
path: ${{ runner.temp }}/digests/*
merge:
needs: build
if: github.repository_owner == 'Homebrew' && needs.build.outputs.push == 'true'
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
version: ["18.04", "20.04", "22.04", "24.04"]
steps:
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5 # v3.8.0
with:
cache-binary: false
- name: Download Docker image digests
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8
with:
path: ${{ runner.temp }}/digests
pattern: digest-${{ matrix.version }}-*
merge-multiple: true
- name: Log in to Docker Hub
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0 uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0
with: with:
username: brewtestbot username: brewtestbot
password: ${{ secrets.HOMEBREW_BREW_DOCKER_TOKEN }} password: ${{ secrets.HOMEBREW_BREW_DOCKER_TOKEN }}
- name: Deploy the tagged Docker image - name: Log in to GitHub Packages (BrewTestBot)
if: steps.attributes.outputs.push == 'true' uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0
uses: docker/build-push-action@471d1dc4e07e5cdedd4c2171150001c434f0b7a4 # v6.15.0
with: with:
context: . registry: ghcr.io
push: true username: BrewTestBot
tags: ${{ steps.attributes.outputs.tags }} password: ${{ secrets.HOMEBREW_BREW_GITHUB_PACKAGES_TOKEN }}
cache-from: type=registry,ref=ghcr.io/homebrew/ubuntu${{ matrix.version }}:cache
cache-to: type=registry,ref=ghcr.io/homebrew/ubuntu${{ matrix.version }}:cache,mode=max - name: Merge and push Docker image
build-args: version=${{ matrix.version }} run: |
labels: ${{ steps.attributes.outputs.labels }} tag_args=()
while IFS=$'\n' read -r tag; do
[[ -n "${tag}" ]] || continue
tag_args+=("--tag=${tag}")
done <<<"${TAGS}"
docker buildx imagetools create \
"${tag_args[@]}" \
"ghcr.io/homebrew/ubuntu${VERSION}@sha256:$(cat "${RUNNER_TEMP}/digests/${VERSION}-x86_64")" \
"ghcr.io/homebrew/ubuntu${VERSION}@sha256:$(cat "${RUNNER_TEMP}/digests/${VERSION}-arm64")"
env:
TAGS: ${{ needs.build.outputs.tags }}
VERSION: ${{ matrix.version }}