--- name: CI permissions: actions: read checks: read contents: read deployments: read issues: read discussions: read pull-requests: read repository-projects: read security-events: read statuses: read on: push: tags: - v* branches: - master - stable - v1 release: types: - published - released pull_request: types: - opened - edited - reopened - synchronize - ready_for_review jobs: # test: # name: Test # runs-on: ubuntu-latest # timeout-minutes: 10 # steps: # - name: Checkout # uses: actions/checkout@v6 # with: # submodules: recursive # # - uses: jdx/mise-action@v3 # name: Install mise # # - name: Run tests # run: mise tasks run covtest # # - name: Collect coverage # uses: codecov/codecov-action@v5 # with: # files: ./coverage.txt # # fuzz: # name: Fuzzing # runs-on: ubuntu-latest # timeout-minutes: 20 # steps: # - name: Checkout # uses: actions/checkout@v6 # with: # submodules: recursive # # - uses: jdx/mise-action@v3 # name: Install mise # # - name: Run fuzzing # run: mise tasks run 'test:fuzz:*' # # # lint: # name: Lint # runs-on: ubuntu-latest # timeout-minutes: 5 # steps: # - name: Checkout # uses: actions/checkout@v6 # with: # submodules: recursive # # - uses: jdx/mise-action@v3 # name: Install mise # # - name: Run linter # run: mise tasks run lint docker: name: Docker runs-on: ubuntu-latest timeout-minutes: 20 steps: - name: Checkout uses: actions/checkout@v6 with: submodules: recursive - name: Get Docker meta id: meta uses: docker/metadata-action@v5 with: images: nineseconds/mtg tags: | type=semver,pattern={{version}} - name: Setup QEMU uses: docker/setup-qemu-action@v3 - name: Setup BuildX uses: docker/setup-buildx-action@v3 - name: Setup cache uses: actions/cache@v5 with: path: /tmp/buildx-cache key: ${{ runner.os }}-buildx-${{ github.sha }} restore-keys: | ${{ runner.os }}-buildx- - name: Login to DockerHub # if: github.event_name != 'pull_request' uses: docker/login-action@v3 with: username: ${{ secrets.DOCKERHUB_USERNAME }} password: ${{ secrets.DOCKERHUB_PASSWORD }} - name: Build and push uses: docker/build-push-action@v2 with: pull: true context: . platforms: linux/amd64,linux/arm64,linux/386,linux/arm/v7,linux/arm/v6 push: false tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} cache-from: type=local,src=/tmp/buildx-cache cache-to: type=local,dest=/tmp/buildx-cache