diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 1656b78..36d7c68 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,38 +1,145 @@ name: build on: - pull_request: push: - tags: - - '*' workflow_dispatch: -permissions: - contents: read +env: + REGISTRY_IMAGE: ghcr.io/voinetwork/voi-node jobs: - test: + prepare: runs-on: ubuntu-latest + outputs: + matrix: ${{ steps.platforms.outputs.matrix }} + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Create matrix + id: platforms + run: | + echo "matrix=$(docker buildx bake image-all --print | jq -cr '.target."image-all".platforms')" >>${GITHUB_OUTPUT} + + - name: Show matrix + run: | + echo ${{ steps.platforms.outputs.matrix }} + + - name: Docker meta + id: meta + uses: docker/metadata-action@v5 + with: + images: ${{ env.REGISTRY_IMAGE }} + + - name: Rename meta bake definition file + run: | + mv "${{ steps.meta.outputs.bake-file }}" "/tmp/bake-meta.json" + + - name: Upload meta bake definition + uses: actions/upload-artifact@v4 + with: + name: bake-meta + path: /tmp/bake-meta.json + if-no-files-found: error + retention-days: 1 + + build: + runs-on: ubuntu-latest + needs: + - prepare strategy: + fail-fast: false matrix: - platform: [ linux/amd64, linux/arm64 ] + platform: ${{ fromJson(needs.prepare.outputs.matrix) }} steps: + - name: Prepare + run: | + platform=${{ matrix.platform }} + echo "PLATFORM_PAIR=${platform//\//-}" >> $GITHUB_ENV + - name: Checkout uses: actions/checkout@v4 - - name: Setup Go - uses: actions/setup-go@v5 + + - name: Download meta bake definition + uses: actions/download-artifact@v4 with: - go-version-file: 'go.mod' - cache: true + name: bake-meta + path: /tmp + - name: Set up QEMU uses: docker/setup-qemu-action@v3 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + + - name: Login to Docker Hub + uses: docker/login-action@v3 with: - platforms: ${{ matrix.platform }} + username: ${{ vars.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + + - name: Build + id: bake + uses: docker/bake-action@v5 + with: + files: | + ./bake.hcl + /tmp/bake-meta.json + targets: image + set: | + *.tags= + *.platform=${{ matrix.platform }} + *.output=type=image,"name=${{ env.REGISTRY_IMAGE }}",push-by-digest=true,name-canonical=true,push=true + + - name: Export digest + run: | + mkdir -p /tmp/digests + digest="${{ fromJSON(steps.bake.outputs.metadata).image['containerimage.digest'] }}" + touch "/tmp/digests/${digest#sha256:}" + + - name: Upload digest + uses: actions/upload-artifact@v4 + with: + name: digests-${{ env.PLATFORM_PAIR }} + path: /tmp/digests/* + if-no-files-found: error + retention-days: 1 + + merge: + runs-on: ubuntu-latest + needs: + - build + steps: + - name: Download meta bake definition + uses: actions/download-artifact@v4 + with: + name: bake-meta + path: /tmp + + - name: Download digests + uses: actions/download-artifact@v4 + with: + path: /tmp/digests + pattern: digests-* + merge-multiple: true + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 + + - name: Log in to the Container registry + uses: docker/login-action@65b78e6e13532edd9afa3aa52ac7964289d1a9c1 with: - version: latest - - name: Run Bake - run: docker buildx bake --file bake.hcl --set *.platform=${{ matrix.platform }} --load - - name: Run Unit Tests - run: make test \ No newline at end of file + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Create manifest list and push + if: env.PUSH_IMAGES == 'true' + working-directory: /tmp/digests + run: | + docker buildx imagetools create $(jq -cr '.target."docker-metadata-action".tags | map(select(startswith("${{ env.REGISTRY_IMAGE }}")) | "-t " + .) | join(" ")' /tmp/bake-meta.json) \ + $(printf '${{ env.REGISTRY_IMAGE }}@sha256:%s ' *) + + - name: Inspect image + run: | + docker buildx imagetools inspect ${{ env.REGISTRY_IMAGE }}:$(jq -r '.target."docker-metadata-action".args.DOCKER_META_VERSION' /tmp/bake-meta.json) \ No newline at end of file diff --git a/bake.hcl b/bake.hcl index 9f59014..7501218 100644 --- a/bake.hcl +++ b/bake.hcl @@ -1,31 +1,32 @@ -group "default" { - targets = ["build", "test", "all"] +variable "DEFAULT_TAG" { + default = "app:local" } -target "build" { - platforms = ["linux/amd64", "linux/arm64"] - tags = ["voi-node"] - context = "." - dockerfile = "Dockerfile" +// Special target: https://github.com/docker/metadata-action#bake-definition +target "docker-metadata-action" { + tags = ["${DEFAULT_TAG}"] } -target "test" { - inherits = ["build"] - args = { - TARGET = "test" - } - commands = [ - "make test" - ] +// Default target if none specified +group "default" { + targets = ["image-local"] } -target "all" { - inherits = ["build"] - args = { - TARGET = "all" - } +target "image" { + inherits = ["docker-metadata-action"] +} + +target "image-local" { + inherits = ["image"] + output = ["type=docker"] +} - commands = [ - "make all" +target "image-all" { + inherits = ["image"] + platforms = [ + "linux/amd64", + "linux/arm/v6", + "linux/arm/v7", + "linux/arm64" ] } \ No newline at end of file