name: Publish Docker image on: push: tags: - 'v*' branches: - main env: REGISTRY: ghcr.io IMAGE_NAME: ${{ github.repository }} permissions: contents: read jobs: test: name: Test runs-on: ubuntu-latest timeout-minutes: 10 services: postgres: image: postgres env: POSTGRES_USER: postgres POSTGRES_PASSWORD: postgres ports: - 5432:5432 options: --health-cmd="pg_isready" --health-interval=10s --health-timeout=5s --health-retries=3 steps: - name: Install packages run: sudo apt-get update && sudo apt-get install --no-install-recommends -y google-chrome-stable curl libvips postgresql-client libpq-dev - name: Checkout code uses: actions/checkout@v4 - name: Set up Ruby uses: ruby/setup-ruby@v1 with: ruby-version: .ruby-version bundler-cache: true - name: Run tests and smoke test seed env: RAILS_ENV: test DATABASE_URL: postgres://postgres:postgres@localhost:5432 run: | bin/rails db:create bin/rails db:schema:load bin/rails test:all bin/rails db:seed - name: Keep screenshots from failed system tests uses: actions/upload-artifact@v4 if: failure() with: name: screenshots path: ${{ github.workspace }}/tmp/screenshots if-no-files-found: ignore build: name: Build docker image runs-on: ubuntu-latest needs: [test] permissions: packages: write steps: - name: Check out the repo uses: actions/checkout@v4 - name: Set up Docker Context for Buildx run: docker context create builders shell: bash - name: Log in to the container registry uses: docker/login-action@v3 with: registry: ${{ env.REGISTRY }} username: ${{ github.actor }} password: ${{ secrets.GITHUB_TOKEN }} - name: Extract metadata for Docker id: meta uses: docker/metadata-action@v5 with: images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} flavor: latest=auto tags: | # Explicit commit sha and version tags type=sha type=semver,pattern={{version}} # Aliases type=raw,value=latest,enable=${{ github.ref == 'refs/heads/main' }} type=raw,value=stable,enable=${{ startsWith(github.ref, 'refs/tags/v') }} - name: Build and push Docker image uses: docker/build-push-action@v5 id: build with: context: . push: true tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }}