Add virtualizer to mobile rules list (#5899) #1136
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 push to master | |
on: | |
push: | |
branches: | |
- master | |
workflow_dispatch: | |
concurrency: | |
group: docker-edge-build | |
cancel-in-progress: true | |
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 }} |