Skip to content

Deploy to Development #16

Deploy to Development

Deploy to Development #16

Workflow file for this run

name: Deploy to Development
concurrency:
group: dev-${{ github.ref }}
cancel-in-progress: true
on:
workflow_dispatch:
inputs:
ttl:
description: "Deployment time to live in seconds"
required: true
type: number
default: 86400
env:
artifact-retention-days: 3
jobs:
build-backend:
name: Build Backend Image
runs-on: ubuntu-latest
outputs:
sha_short: ${{ steps.vars.outputs.sha_short }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Set vars
id: vars
run: |
echo "sha_short=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_ENV
echo "sha_short=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_OUTPUT
- name: Build Image with Tag
run: |
docker build --target backend-prod --tag "${{ secrets.DOCKER_USERNAME }}/bt-backend:${{ env.sha_short }}" .
docker save "${{ secrets.DOCKER_USERNAME }}/bt-backend:${{ env.sha_short }}" --output "bt-backend-${{ env.sha_short }}.tar"
- name: Upload Image as Artifact
uses: actions/upload-artifact@v4
with:
name: "bt-backend-${{ env.sha_short }}.tar"
path: "bt-backend-${{ env.sha_short }}.tar"
retention-days: ${{ env.artifact-retention-days }}
overwrite: true
build-frontend:
name: Build Frontend Image
runs-on: ubuntu-latest
outputs:
sha_short: ${{ steps.vars.outputs.sha_short }}
steps:
- name: Checkout Repository
uses: actions/checkout@v4
- name: Set vars
id: vars
run: |
echo "sha_short=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_ENV
echo "sha_short=$(git rev-parse --short ${{ github.sha }})" >> $GITHUB_OUTPUT
- name: Build Image with Tag
run: |
docker build --target frontend-prod --tag "${{ secrets.DOCKER_USERNAME }}/bt-frontend:${{ env.sha_short }}" .
docker save "${{ secrets.DOCKER_USERNAME }}/bt-frontend:${{ env.sha_short }}" --output "bt-frontend-${{ env.sha_short }}.tar"
- name: Upload Image as Artifact
uses: actions/upload-artifact@v4
with:
name: "bt-frontend-${{ env.sha_short }}.tar"
path: "bt-frontend-${{ env.sha_short }}.tar"
retention-days: ${{ env.artifact-retention-days }}
overwrite: true
push-backend:
name: Push Backend Image
needs: build-backend
runs-on: ubuntu-latest
outputs:
sha_short: ${{ steps.vars.outputs.sha_short }}
steps:
- name: Receive and Forward sha_short
id: vars
run: |
echo "sha_short=${{ needs.build-backend.outputs.sha_short }}" >> $GITHUB_ENV
echo "sha_short=${{ needs.build-backend.outputs.sha_short }}" >> $GITHUB_OUTPUT
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Download Artifact as Image
uses: actions/download-artifact@v4
with:
name: "bt-backend-${{ env.sha_short }}.tar"
- name: Push Image to Docker Hub
run: |
docker import "bt-backend-${{ env.sha_short }}.tar" "${{ secrets.DOCKER_USERNAME }}/bt-backend:${{ env.sha_short }}"
docker push "${{ secrets.DOCKER_USERNAME }}/bt-backend:${{ env.sha_short }}"
push-frontend:
name: Push Frontend Image
needs: build-frontend
runs-on: ubuntu-latest
outputs:
sha_short: ${{ steps.vars.outputs.sha_short }}
steps:
- name: Receive and Forward sha_short
id: vars
run: |
echo "sha_short=${{ needs.build-frontend.outputs.sha_short }}" >> $GITHUB_ENV
echo "sha_short=${{ needs.build-frontend.outputs.sha_short }}" >> $GITHUB_OUTPUT
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Download Artifact as Image
uses: actions/download-artifact@v4
with:
name: "bt-frontend-${{ env.sha_short }}.tar"
- name: Push Image to Docker Hub
run: |
docker import "bt-frontend-${{ env.sha_short }}.tar" "${{ secrets.DOCKER_USERNAME }}/bt-frontend:${{ env.sha_short }}"
docker push "${{ secrets.DOCKER_USERNAME }}/bt-frontend:${{ env.sha_short }}"
deploy:
name: Deploy with SSH
needs: [push-backend, push-frontend]
runs-on: ubuntu-latest
environment: development
steps:
- name: Receive sha_short
run: echo "sha_short=${{ needs.push-backend.outputs.sha_short }}" >> $GITHUB_ENV
- name: SSH and Helm Install
uses: appleboy/[email protected]
with:
host: ${{ secrets.SSH_HOST }}
username: ga
key: ${{ secrets.SSH_KEY }}
script: |
cd ./infra
helm uninstall bt-dev-app-${{ env.sha_short }} || true
helm install bt-dev-app-${{ env.sha_short }} ./app --namespace=bt \
--set env=dev \
--set ttl=${{ inputs.ttl }} \
--set frontend.image.tag=${{ env.sha_short }} \
--set backend.image.tag=${{ env.sha_short }} \
--set host=${{ env.sha_short }}.stanfurdtime.com \
--set mongoUri=mongodb://bt-dev-mongo-mongodb.bt.svc.cluster.local:27017/bt \
--set redisUri=redis://bt-dev-redis-master.bt.svc.cluster.local:6379 \
--set nodeEnv=development