From 35b9cf9cf3de40083cca4c563222add2a04a3963 Mon Sep 17 00:00:00 2001 From: barnstee Date: Wed, 2 Oct 2024 22:56:32 +0200 Subject: [PATCH] merge GitHub actions and build a single multi-platform Docker container image. --- .github/workflows/docker-publish.yml | 24 +++++++++++++++--------- UAEdgeTranslator.sln | 2 -- 2 files changed, 15 insertions(+), 11 deletions(-) diff --git a/.github/workflows/docker-publish.yml b/.github/workflows/docker-publish.yml index 8e459ab..c49d1e6 100644 --- a/.github/workflows/docker-publish.yml +++ b/.github/workflows/docker-publish.yml @@ -1,3 +1,4 @@ +--- name: Docker # This workflow uses actions that are not certified by GitHub. @@ -5,15 +6,16 @@ name: Docker # separate terms of service, privacy policy, and support # documentation. -on: +on: # yamllint disable-line rule:truthy schedule: - - cron: '23 9 * * *' + - cron: "23 9 * * *" push: branches: [ main ] # Publish semver tags as releases. - tags: [ 'v*.*.*' ] + tags: ["v*.*.*"] pull_request: branches: [ main ] + merge_group: env: # Use docker.io for Docker Hub if empty @@ -21,10 +23,8 @@ env: # github.repository as / IMAGE_NAME: ${{ github.repository }} - jobs: build: - runs-on: ubuntu-latest permissions: contents: read @@ -32,13 +32,13 @@ jobs: steps: - name: Checkout repository - uses: actions/checkout@v2 + uses: actions/checkout@v4.2.0 # Login against a Docker registry except on PR # https://github.com/docker/login-action - name: Log into registry ${{ env.REGISTRY }} if: github.event_name != 'pull_request' - uses: docker/login-action@28218f9b04b4f3f62068d7b6ce6ca5b26e35336c + uses: docker/login-action@v3.3.0 with: registry: ${{ env.REGISTRY }} username: ${{ github.actor }} @@ -48,16 +48,22 @@ jobs: # https://github.com/docker/metadata-action - name: Extract Docker metadata id: meta - uses: docker/metadata-action@98669ae865ea3cffbcbaa878cf57c20bbf1c6c38 + uses: docker/metadata-action@v5.5.1 with: images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + - name: Set up QEMU + uses: docker/setup-qemu-action@v3.2.0 + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3.6.1 + # Build and push Docker image with Buildx (don't push on PR) # https://github.com/docker/build-push-action - name: Build and push Docker image - uses: docker/build-push-action@ad44023a93711e3deb337508980b4b5e9bcdc5dc + uses: docker/build-push-action@v6.7.0 with: context: . + platforms: linux/amd64,linux/arm64 push: ${{ github.event_name != 'pull_request' }} tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} diff --git a/UAEdgeTranslator.sln b/UAEdgeTranslator.sln index 271615c..1bbac70 100644 --- a/UAEdgeTranslator.sln +++ b/UAEdgeTranslator.sln @@ -7,9 +7,7 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "UAEdgeTranslator", "UAEdgeT EndProject Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{28C9D48D-859A-4F4C-AD74-BF380A944330}" ProjectSection(SolutionItems) = preProject - .github\workflows\docker-publish-arm64.yml = .github\workflows\docker-publish-arm64.yml .github\workflows\docker-publish.yml = .github\workflows\docker-publish.yml - Samples\pac4200.jsonld = Samples\pac4200.jsonld EndProjectSection EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WoTThingModelGenerator", "WoTThingModelGenerator\WoTThingModelGenerator.csproj", "{37DCF037-4101-45F1-8AF1-5A5D1195C636}"