name: CI on: push: pull_request: workflow_dispatch: jobs: test_host: runs-on: ubuntu-latest name: Test (host) steps: - name: Checkout uses: actions/checkout@v4 - name: Install dependencies run: sudo apt install -y wireguard-tools - name: Test run: sudo ./test/host/test.sh test_linuxserver: runs-on: ubuntu-latest name: Test (LinuxServer) steps: - name: Checkout uses: actions/checkout@v4 - name: Test run: sudo ./test/linuxserver/test.sh publish: needs: [test_host, test_linuxserver] runs-on: ubuntu-latest name: 'Publish' if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/')) steps: - name: Checkout uses: actions/checkout@v4 # https://github.com/docker/metadata-action#semver - id: meta name: Docker Hub metadata uses: docker/metadata-action@v5 with: images: egortensin/wg-api-web flavor: | latest=auto tags: | type=ref,event=branch type=semver,pattern={{version}} type=semver,pattern={{major}}.{{minor}} type=semver,pattern={{major}} - 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: username: egortensin password: '${{ secrets.DOCKERHUB_TOKEN }}' - id: platforms name: Which platforms? # Building for ARM for every commit in master is too time-consuming. run: | if [ '${{ github.ref }}' = 'refs/heads/master' ]; then echo 'platforms=amd64' >> "$GITHUB_OUTPUT" else echo 'platforms=amd64,armhf,arm64' >> "$GITHUB_OUTPUT" fi - name: Build and publish uses: docker/build-push-action@v5 with: # Without context, .dockerignore isn't respected? # https://stackoverflow.com/a/74552407/514684 context: . labels: '${{ steps.meta.outputs.labels }}' platforms: '${{ steps.platforms.outputs.platforms }}' push: true tags: '${{ steps.meta.outputs.tags }}'