Build Edge Docker Image #2
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Build Edge Docker Image | |
| # Edge Docker images are built for every commit, and daily | |
| on: | |
| push: | |
| branches: | |
| - master | |
| paths: | |
| - 'packages/sync-server/**' | |
| pull_request: | |
| branches: | |
| - master | |
| paths: | |
| - 'packages/sync-server/**' | |
| schedule: | |
| - cron: '0 0 * * *' | |
| workflow_dispatch: | |
| permissions: | |
| contents: read | |
| packages: write | |
| env: | |
| IMAGES: | | |
| ${{ !github.event.repository.fork && 'actualbudget/actual-server' || '' }} | |
| ghcr.io/${{ github.repository_owner }}/actual-server | |
| ghcr.io/${{ github.repository_owner }}/actual | |
| # Creates the following tags: | |
| # - actual-server:edge | |
| TAGS: | | |
| type=edge,value=edge | |
| type=sha | |
| jobs: | |
| build: | |
| if: github.event_name == 'workflow_dispatch' || !github.event.repository.fork | |
| name: Build Docker image | |
| runs-on: ubuntu-latest | |
| strategy: | |
| matrix: | |
| os: [ubuntu, alpine] | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - name: Set up QEMU | |
| uses: docker/setup-qemu-action@v3 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v3 | |
| - name: Docker meta | |
| id: meta | |
| uses: docker/metadata-action@v5 | |
| with: | |
| # Push to both Docker Hub and Github Container Registry | |
| images: ${{ env.IMAGES }} | |
| flavor: ${{ matrix.os != 'ubuntu' && format('suffix=-{0}', matrix.os) || '' }} | |
| tags: ${{ env.TAGS }} | |
| - name: Login to Docker Hub | |
| uses: docker/login-action@v3 | |
| if: github.event_name != 'pull_request' && !github.event.repository.fork | |
| with: | |
| username: ${{ secrets.DOCKERHUB_USERNAME }} | |
| password: ${{ secrets.DOCKERHUB_TOKEN }} | |
| - name: Login to GitHub Container Registry | |
| uses: docker/login-action@v3 | |
| if: github.event_name != 'pull_request' | |
| with: | |
| registry: ghcr.io | |
| username: ${{ github.repository_owner }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| # Building outside of the docker image allows us to build once and push to multiple platforms | |
| # This is faster and avoids yarn memory issues | |
| - name: Set up environment | |
| uses: ./.github/actions/setup | |
| - name: Build Web | |
| run: yarn build:server | |
| - name: Build image for testing | |
| uses: docker/build-push-action@v5 | |
| with: | |
| context: . | |
| push: false | |
| load: true | |
| file: packages/sync-server/docker/${{ matrix.os }}.Dockerfile | |
| tags: actualbudget/actual-server-testing | |
| - name: Test that the docker image boots | |
| run: | | |
| docker run --detach --network=host actualbudget/actual-server-testing | |
| sleep 5 | |
| curl --fail -sS -LI -w '%{http_code}\n' --retry 10 --retry-delay 1 --retry-connrefused localhost:5006 | |
| # This will use the cache from the earlier build step and not rebuild the image | |
| # https://docs.docker.com/build/ci/github-actions/test-before-push/ | |
| - name: Build and push images | |
| uses: docker/build-push-action@v5 | |
| with: | |
| context: . | |
| push: ${{ github.event_name != 'pull_request' }} | |
| file: packages/sync-server/docker/${{ matrix.os }}.Dockerfile | |
| platforms: linux/amd64,linux/arm64,linux/arm/v7${{ matrix.os == 'alpine' && ',linux/arm/v6' || '' }} | |
| tags: ${{ steps.meta.outputs.tags }} | |
| build-args: | | |
| GITHUB_TOKEN=${{ secrets.GITHUB_TOKEN }} |