Ensure we deploy the pushed image #32
This file contains 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: CI | |
on: | |
push: | |
branches: | |
- 'main' | |
pull_request: | |
schedule: | |
- cron: '0 0 * * *' | |
permissions: | |
contents: read | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }} | |
env: | |
OBSERVABLE_TELEMETRY_DISABLE: 1 | |
jobs: | |
build-image: | |
name: 'Build image' | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 30 | |
outputs: | |
image: ${{ steps.build.outputs.imageid }} | |
steps: | |
- name: 'Checkout code' | |
uses: actions/[email protected] | |
- name: 'Set up Docker Build' | |
uses: docker/[email protected] | |
- name: 'Build image' | |
id: build | |
uses: docker/[email protected] | |
with: | |
outputs: type=docker,dest=/tmp/image.tar | |
cache-from: type=gha,ignore-error=true | |
cache-to: type=gha,mode=max,ignore-error=true | |
no-cache-filters: build | |
target: prod | |
- name: 'Upload build' | |
uses: actions/[email protected] | |
with: | |
name: image | |
path: /tmp/image.tar | |
format: | |
name: 'Format' | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 30 | |
if: github.event_name != 'schedule' | |
steps: | |
- name: 'Checkout code' | |
uses: actions/[email protected] | |
- name: 'Set up Node.js' | |
uses: actions/[email protected] | |
with: | |
node-version-file: package.json | |
cache: ${{ !env.ACT && 'npm' || '' }} | |
- name: 'Install dependencies' | |
run: npm ci | |
- name: 'Run formatter' | |
run: npx prettier --ignore-unknown --check '**' | |
push: | |
name: 'Push image' | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 30 | |
if: github.ref == 'refs/heads/main' && !failure() && !cancelled() | |
outputs: | |
image: ${{ steps.image.outputs.image }} | |
needs: | |
- build-image | |
- format | |
steps: | |
- name: 'Set up flyctl' | |
uses: superfly/flyctl-actions/[email protected] | |
- name: 'Log in to the registry' | |
run: flyctl auth docker | |
env: | |
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }} | |
- name: 'Download image' | |
uses: actions/[email protected] | |
with: | |
name: image | |
path: /tmp | |
- name: 'Load image' | |
run: docker load --input /tmp/image.tar | |
- name: 'Generate image name' | |
id: image | |
run: echo "image=registry.fly.io/prereview-stats:${{ github.sha }}-${{ github.run_id }}-${{ github.run_attempt }}" >> $GITHUB_OUTPUT | |
- name: 'Tag image' | |
run: docker tag ${{ needs.build-image.outputs.image }} ${{ steps.image.outputs.image }} | |
- name: 'Push image' | |
run: docker push ${{ steps.image.outputs.image }} | |
deploy: | |
name: 'Deploy' | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 30 | |
if: github.ref == 'refs/heads/main' && !failure() && !cancelled() | |
needs: | |
- push | |
steps: | |
- name: 'Checkout code' | |
uses: actions/[email protected] | |
with: | |
sparse-checkout: fly.toml | |
sparse-checkout-cone-mode: false | |
- name: 'Set up flyctl' | |
uses: superfly/flyctl-actions/[email protected] | |
- name: 'Deploy app' | |
run: flyctl deploy --image ${{ needs.push.outputs.image }} | |
env: | |
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }} | |
notify: | |
name: 'Notify of failure' | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 30 | |
needs: | |
- deploy | |
if: failure() && github.ref == 'refs/heads/main' | |
steps: | |
- uses: voxmedia/[email protected] | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.SLACK_NOTIFICATIONS_BOT_TOKEN }} | |
with: | |
channel_id: G015ZLXJA9W | |
status: FAILED | |
color: danger |