Skip to content

chore(docker): build ghcr image for alpha branch #209

chore(docker): build ghcr image for alpha branch

chore(docker): build ghcr image for alpha branch #209

name: Build ghcr.io image
on:
push:
branches: [ 'main', '*dev*', '*alpha*', '*beta*', '*rc*' ]
tags:
workflow_dispatch:
inputs:
commit_sha:
description: 'Commit SHA to build'
required: true
jobs:
build-amd64-image-to-ghcr:
runs-on: ubuntu-22.04
env:
REGISTRY: 'ghcr.io/'
IMAGE_NAME: axon
# If you specify the access for any of these scopes, all of those that are not specified are set to none.
permissions:
contents: read
packages: write
steps:
- uses: actions/checkout@v4
with:
ref: ${{ github.event.inputs.commit_sha || '' }}
# Extract metadata (tags, labels) for the Docker image
# https://github.com/docker/metadata-action
- name: Extract Docker metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}${{ github.repository_owner }}/${{ env.IMAGE_NAME }}
flavor: |
latest=auto
tags: |
type=ref,event=tag
type=semver,pattern={{version}}
type=ref,event=branch
type=ref,event=branch,suffix=-{{date 'YYYYMMDDHHmm'}}
type=ref,event=branch,suffix=-{{sha}}
# minimal (short sha)
type=sha,enable=true,prefix=sha-,format=short
- name: Echo steps.meta.outputs.bake-file
run: cat ${{ steps.meta.outputs.bake-file }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Github resgistry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Build and push image to ${{ env.REGISTRY }}${{ github.repository_owner }}/${{ env.IMAGE_NAME }}
uses: docker/build-push-action@v5
with:
context: .
file: ./Dockerfile
platforms: linux/amd64
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
- name: Check versions of the binaries in ${{ fromJSON(steps.meta.outputs.json).tags[0] }}
if: ${{ github.event_name != 'pull_request' }}
env:
IMAGE: ${{ fromJSON(steps.meta.outputs.json).tags[0] }}
run: |
docker run --rm ${{ env.IMAGE }} /app/axon --version
- name: Record image info to the outputs of this job
id: result
run: |
echo "image_name=`echo ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | awk -F ':' '{print $1}'`" >> $GITHUB_OUTPUT
echo "image_tag=`echo ${{ fromJSON(steps.meta.outputs.json).tags[0] }} | awk -F ':' '{print $NF}'`" >> $GITHUB_OUTPUT
# Map the meta step outputs to this job outputs
outputs:
image_name: ${{ steps.result.outputs.image_name }}
image_tag: ${{ steps.result.outputs.image_tag }}
test-in-docker-compose:
needs: build-amd64-image-to-ghcr
runs-on: ubuntu-22.04
defaults:
run:
working-directory: devtools/chain
steps:
- name: Checkout devtools/chain
uses: actions/checkout@v4
with:
sparse-checkout: |
devtools/chain
devtools/ci/scripts/helper.js
- name: Modify the Axon image of in devtools/chain/docker-compose.yml
env:
AXON_IMAGE: "${{ needs.build-amd64-image-to-ghcr.outputs.image_name }}:${{ needs.build-amd64-image-to-ghcr.outputs.image_tag }}"
uses: mikefarah/[email protected]
with:
cmd: yq -i '.services.axon.image = "${{ env.AXON_IMAGE }}"' 'devtools/chain/docker-compose.yml'
- name: Review devtools/chain/docker-compose.yml
run: |
echo "====== devtools/chain/docker-compose.yml ======"
cat docker-compose.yml
echo "==============================================="
docker -v
- name: Run docker compose (v2) up and check the Axon node's health
run: |
echo "start containers in detached mode and wait for them to become healthy"
docker compose up -d --wait
docker compose ps
docker compose logs --tail 6
npx zx <<'EOF'
import { waitXBlocksPassed } from '../ci/scripts/helper.js'
await retry(3, '6s', () => waitXBlocksPassed('http://127.0.0.1:8000', 2))
EOF
timeout-minutes: 2