Skip to content

Commit

Permalink
chore: add deploy job in staging workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
cybersiddhu committed Nov 19, 2020
1 parent 923f131 commit 139f87c
Showing 1 changed file with 68 additions and 5 deletions.
73 changes: 68 additions & 5 deletions .github/workflows/staging-build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ on:
- staging
jobs:
build:
runs-on: ubuntu-latest
runs-on: ubuntu-20.04
steps:
- name: set up golang
uses: actions/setup-go@v2
Expand All @@ -28,15 +28,78 @@ jobs:
username: ${{ secrets.DOCKER_USER }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: get short sha
id: type
id: vars
run: |
sha=$(git rev-parse --short HEAD)
echo ::set-output name=id::${sha}
echo ::set-output name=image_tag::${sha}
- name: docker build and push
uses: docker/build-push-action@v2
with:
push: true
file: build/package/Dockerfile
tags: dictybase/modware-content:staging-${{ steps.type.outputs.id }}
tags: dictybase/${{ github.event.repository.name }}:staging-${{ steps.vars.outputs.image_tag }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache
- name: prepare for deploy
if: ${{ success() }}
id: prepare_deploy
uses: dictybase-docker/prepare-deploy@v2
with:
cluster-name: staging
cluster-zone: "us-central1-a"
namespace: dictybase
chart-name: content-api-server
chart-path: deployments/charts/content-api-server
token: ${{ secrets.GITHUB_TOKEN }}
image-tag: staging-${{ steps.vars.outputs.image_tag }}
ref: ${{ github.ref }}
owner: ${{ github.repository_owner }}
repo: ${{ github.event.repository.name }}
artifact: ${{ github.event.repository.name }}
environment: staging
deploy:
runs-on: ubuntu-20.04
needs: build
steps:
- name: check out code
uses: actions/checkout@v2
- name: download deployment artifact
uses: actions/download-artifact@v2
with:
name: ${{ github.event.repository.name }}
- name: download and setup path for github action binary
run: |
mkdir -p github-actions/bin
curl -L -o github-actions/bin/actions https://github.com/dictybase-docker/github-actions/releases/download/v2.1.4/action_2.1.4_Linux_x86_64
chmod +x github-actions/bin/actions
echo "$GITHUB_WORKSPACE/github-actions/bin" >> $GITHUB_PATH
- name: extract information from deployment payload
id: deploy_info
run: actions --log-level debug sdp -f deployment.json
- name: set in_progress deployment status
if: ${{ success() }}
run: actions --log-level debug -t ${{ secrets.REPO_ACCESS_TOKEN }} --owner ${{ github.repository_owner }} -r ${{ github.event.repository.name }} ds --state in_progress --deployment_id ${{ steps.deploy_info.outputs.id }} --url ${{ steps.deploy_info.outputs.url }}
- name: setup google cloud sdk
uses: GoogleCloudPlatform/github-actions/setup-gcloud@master
with:
version: "313.0.1"
project_id: ${{ secrets.STAGING_PROJECT_ID }}
service_account_key: ${{ secrets.STAGING_SA_KEY }}
export_default_credentials: true
- name: set up helm
uses: azure/setup-helm@v1
with:
version: "v2.16.12"
- name: add dictybase helm repo
run: helm init --client-only && helm repo add dictybase https://dictybase-docker.github.io/kubernetes-charts
- name: get gcloud credentials for k8s cluster
run: gcloud container clusters get-credentials --project ${{ secrets.STAGING_PROJECT_ID }} --zone ${{ steps.deploy_info.outputs.zone }} ${{ steps.deploy_info.outputs.cluster }}
- name: deploy chart
if: ${{ success() }}
run: actions --log-level debug dc --name ${{ steps.deploy_info.outputs.chart }} --namespace ${{ steps.deploy_info.outputs.namespace }} --image-tag ${{ steps.deploy_info.outputs.image_tag }} --path ${{ steps.deploy_info.outputs.path }}
- name: set successful deploy status
if: ${{ success() }}
run: actions --log-level debug -t ${{ secrets.REPO_ACCESS_TOKEN }} --owner ${{ github.repository_owner }} -r ${{ github.event.repository.name }} ds --state success --deployment_id ${{ steps.deploy_info.outputs.id }} --url ${{ steps.deploy_info.outputs.url }}
- name: set unsuccessful deploy status
if: ${{ failure() }}
run: actions --log-level debug -t ${{ secrets.REPO_ACCESS_TOKEN }} --owner ${{ github.repository_owner }} -r ${{ github.event.repository.name }} ds --state error --deployment_id ${{ steps.deploy_info.outputs.id }} --url ${{ steps.deploy_info.outputs.url }}

0 comments on commit 139f87c

Please sign in to comment.