Skip to content

chore(snackpub): update Dockerfile for yarn-related changes (#622) #316

chore(snackpub): update Dockerfile for yarn-related changes (#622)

chore(snackpub): update Dockerfile for yarn-related changes (#622) #316

Workflow file for this run

name: Snackpub
defaults:
run:
working-directory: snackpub
concurrency:
group: snackpub-${{ github.event_name }}-${{ github.ref }}
cancel-in-progress: true
on:
workflow_dispatch:
inputs:
deploy:
description: What environment should be deployed
type: choice
default: no-deploy
options:
- no-deploy
- staging
- production
pull_request:
paths:
- .github/actions/setup-google-cloud/**
- .github/actions/setup-snackpub/**
- .github/workflows/snackpub.yml
- snackpub/**
- .eslint*
- .prettier*
- yarn.lock
- turbo.json
push:
branches: [main]
paths:
- .github/actions/setup-google-cloud/**
- .github/actions/setup-snackpub/**
- .github/workflows/snackpub.yml
- snackpub/**
- .eslint*
- .prettier*
- yarn.lock
- turbo.json
jobs:
review:
runs-on: ubuntu-latest
steps:
- name: πŸ— Setup repository
uses: actions/checkout@v3
- name: πŸ— Setup snackpub
uses: ./.github/actions/setup-snackpub
- name: 🚨 Lint snackpub
run: yarn lint --max-warnings 0
- name: πŸ§ͺ Test snackpub
run: yarn test --ci --maxWorkers 1
build:
if: ${{ github.event_name == 'pull_request' }}
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
steps:
- name: πŸ— Setup repository
uses: actions/checkout@v3
- name: πŸ— Setup Google Cloud SDK
uses: ./.github/actions/setup-google-cloud
with:
auth: true
- name: πŸ›  Build snackpub
run: skaffold build --filename snackpub/skaffold.yaml
working-directory: ./
deploy-staging:
if: ${{ (github.event.inputs.deploy == 'staging' && github.event_name != 'pull_request') || (github.event_name == 'push' && github.ref == 'refs/heads/main') }}
needs: review
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
environment:
name: snackpub-staging
steps:
- name: πŸ— Setup repository
uses: actions/checkout@v3
- name: πŸ— Setup Google Cloud SDK
uses: ./.github/actions/setup-google-cloud
with:
auth: true
- name: πŸ›  Build snackpub
run: skaffold build --filename snackpub/skaffold.yaml --file-output /tmp/build.json
working-directory: ./
env:
SKAFFOLD_PUSH_IMAGE: 'true'
- name: πŸš€ Deploy snackpub to k8s
run: skaffold deploy --status-check --build-artifacts /tmp/build.json
working-directory: snackpub
env:
ENVIRONMENT: staging
- name: πŸ’¬ Notify Slack
uses: 8398a7/action-slack@v3
if: always()
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_SNACK }}
with:
channel: '#snack'
status: ${{ job.status }}
author_name: Deploy Snackpub to Staging
fields: message,commit,author,job,took
deploy-production:
if: ${{ github.event.inputs.deploy == 'production' && github.ref == 'refs/heads/main' }}
needs: review
runs-on: ubuntu-latest
permissions:
contents: read
id-token: write
environment:
name: snackpub-production
steps:
- name: πŸ— Setup repository
uses: actions/checkout@v3
- name: πŸ— Setup Google Cloud SDK
uses: ./.github/actions/setup-google-cloud
with:
auth: true
- name: πŸ›  Build snackpub
run: skaffold build --filename snackpub/skaffold.yaml --file-output /tmp/build.json
working-directory: ./
env:
ENVIRONMENT: production
SKAFFOLD_PUSH_IMAGE: 'true'
- name: πŸš€ Deploy snackpub to k8s
run: skaffold deploy --status-check --build-artifacts /tmp/build.json
working-directory: snackpub
env:
ENVIRONMENT: production
- name: πŸ’¬ Notify Slack
if: ${{ always() }}
uses: 8398a7/action-slack@v3
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_SNACK }}
with:
channel: '#snack'
status: ${{ job.status }}
author_name: Deploy Snackpub to Production
fields: message,commit,author,job,took