Skip to content

test #2

test #2 #6

Workflow file for this run

name: Deploy
on:
push:
branches: [ "prod" ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Docker metadata
id: meta
uses: docker/metadata-action@v4
with:
images: krisjanisp/proglv-backend
tags: |
type=schedule
type=schedule,pattern={{date 'YYYYMMDD-hhmmss'}}
type=sha
- name: Login to DockerHub
if: github.event_name != 'pull_request'
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build and push to DH
uses: docker/build-push-action@v4
with:
context: .
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
- name: Install doctl
uses: digitalocean/action-doctl@v2
with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }}
- name: Create kubernetes directory
run: mkdir -p kubernetes
- name: Download manifest
run: wget https://raw.githubusercontent.com/programme-lv/devops/main/kubernetes/proglv_backend_deployment.yaml -P kubernetes/
- name: Replace manifest tokens
uses: cschleiden/replace-tokens@v1
with:
files: '["kubernetes/*.yaml"]'
tokenPrefix: __
tokenSuffix: __
env:
IMAGE_NAME: "krisjanisp/proglv-backend"
IMAGE_TAG: "1.0"
- name: Log manifest
run: cat ./kubernetes/proglv_backend_deployment.yaml
- name: Save DigitalOcean kubeconfig with short-lived credentials
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.CLUSTER_NAME }}
- name: Deploy to DigitalOcean Kubernetes
run: kubectl apply -f ./kubernetes/proglv_backend_deployment.yaml
- name: Verify deployment
run: kubectl rollout status deployment/proglv-backend