From 0677d278d7a2d11d789518185f2f6bc4efbf3d03 Mon Sep 17 00:00:00 2001 From: Joe Howarth Date: Wed, 18 Jan 2023 13:48:51 -0700 Subject: [PATCH] docker publish --- .github/workflows/docker-publish.yaml | 41 ++++++++++++++++ .github/workflows/test.yaml | 67 +++++++++++++++++++++++++++ 2 files changed, 108 insertions(+) create mode 100644 .github/workflows/docker-publish.yaml diff --git a/.github/workflows/docker-publish.yaml b/.github/workflows/docker-publish.yaml new file mode 100644 index 0000000..7a22101 --- /dev/null +++ b/.github/workflows/docker-publish.yaml @@ -0,0 +1,41 @@ +name: Create and publish a Docker image + +on: + push: + branches: ['release'] + +env: + REGISTRY: ghcr.io + IMAGE_NAME: ${{ github.repository }} + +jobs: + build-and-push-image: + runs-on: ubuntu-latest + permissions: + contents: read + packages: write + + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + - name: Log in to the Container registry + uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 + with: + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@98669ae865ea3cffbcbaa878cf57c20bbf1c6c38 + with: + images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + + - name: Build and push Docker image + uses: docker/build-push-action@ad44023a93711e3deb337508980b4b5e9bcdc5dc + with: + context: ./relayer_engine + push: true + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} \ No newline at end of file diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 60a4f03..72023e2 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -72,3 +72,70 @@ jobs: cd trustless-generic-relayer/relayer_engine npm ci npx tsc --noEmit --project tsconfig.json + + docker-push: + runs-on: ubuntu-latest + steps: + - name: Checkout trustless-generic-relayer + uses: actions/checkout@v3 + with: + path: trustless-generic-relayer + - name: Checkout wormhole + uses: actions/checkout@v3 + with: + repository: wormhole-foundation/wormhole + path: trustless-generic-relayer/ethereum/wormhole + ref: feat/batch_vaa_alternative + - name: Checkout relayer-engine + uses: actions/checkout@v3 + with: + repository: wormhole-foundation/relayer-engine + path: relayer-engine + - uses: actions/setup-node@v3 + with: + node-version: 18 + cache: "npm" + cache-dependency-path: | + trustless-generic-relayer/ethereum/package-lock.json + trustless-generic-relayer/ethereum/wormhole/ethereum/package-lock.json + trustless-generic-relayer/relayer_engine/package-lock.json + trustless-generic-relayer/sdk/package-lock.json + relayer-engine/package-lock.json + - name: Generate contract typechain typings + run: | + cd trustless-generic-relayer/ethereum + ../scripts/install-foundry + PATH=$PATH:$HOME/.foundry/bin/ make build + - run: cd trustless-generic-relayer/sdk && npm ci + - name: Typecheck ethereum/ts-scripts + run: | + cd trustless-generic-relayer/ethereum + npm ci + npx tsc --noEmit --project ts-scripts + - run: cd relayer-engine && npm ci + - name: Typecheck relayer engine plugin + run: | + cd trustless-generic-relayer/relayer_engine + npm ci + npx tsc --noEmit --project tsconfig.json + + - name: Log in to the Container registry + uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 + with: + registry: ${{ env.REGISTRY }} + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Extract metadata (tags, labels) for Docker + id: meta + uses: docker/metadata-action@98669ae865ea3cffbcbaa878cf57c20bbf1c6c38 + with: + images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} + + - name: Build and push Docker image + uses: docker/build-push-action@ad44023a93711e3deb337508980b4b5e9bcdc5dc + with: + context: trustless-generic-relayer/relayer_engine + push: true + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }}