Add 3.3 staging deployment workflow (#2011)
This commit is contained in:
parent
c00d34434c
commit
a93f6aca6f
1 changed files with 76 additions and 0 deletions
76
.github/workflows/deploy-staging-v33.yaml
vendored
Normal file
76
.github/workflows/deploy-staging-v33.yaml
vendored
Normal file
|
@ -0,0 +1,76 @@
|
|||
name: Deploy Dashboard 3.3 to staging
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- 3.3**
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
git_ref:
|
||||
description: Git ref (tag, branch or commit hash) with helm chart to deploy
|
||||
required: true
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-20.04
|
||||
env:
|
||||
API_URI: /graphql/
|
||||
APP_MOUNT_URI: /dashboard/
|
||||
STATIC_URL: /dashboard/static/
|
||||
SENTRY_ORG: saleor
|
||||
SENTRY_PROJECT: dashboard
|
||||
SENTRY_URL_PREFIX: "~/dashboard/static"
|
||||
SENTRY_DSN: ${{ secrets.SENTRY_DSN }}
|
||||
SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }}
|
||||
ENVIRONMENT: saleor-staging-v33
|
||||
IS_CLOUD_INSTANCE: true
|
||||
steps:
|
||||
- uses: actions/checkout@v2
|
||||
with:
|
||||
ref: ${{ github.event.inputs.git_ref || '' }}
|
||||
|
||||
- name: Package
|
||||
timeout-minutes: 15
|
||||
run: |
|
||||
npm ci
|
||||
|
||||
- name: Build
|
||||
run: |
|
||||
npm run build
|
||||
|
||||
- name: Configure AWS Credentials
|
||||
uses: aws-actions/configure-aws-credentials@v1
|
||||
with:
|
||||
aws-access-key-id: ${{ secrets.AWS_DASHBOARD_STAGING_ACCESS_KEY_ID }}
|
||||
aws-secret-access-key: ${{ secrets.AWS_DASHBOARD_STAGING_SECRET_ACCESS_KEY }}
|
||||
aws-region: us-east-1
|
||||
|
||||
- name: Deploy
|
||||
run: |
|
||||
aws s3 sync build/dashboard s3://${{ secrets.AWS_STAGING_DEPLOYMENT_BUCKET }}/${ENVIRONMENT}/static/
|
||||
aws s3 cp build/dashboard/index.html s3://${{ secrets.AWS_STAGING_DEPLOYMENT_BUCKET }}/${ENVIRONMENT}/
|
||||
aws cloudfront create-invalidation --distribution-id ${{ secrets.AWS_STAGING_CF_DIST_ID }} --paths "/dashboard*"
|
||||
|
||||
- name: Prepare Sandbox release pull request
|
||||
run: |
|
||||
export GITHUB_TOKEN=$( \
|
||||
curl --request GET --url ${{ secrets.VAULT_URL}} --header "Authorization: JWT ${{ secrets.VAULT_JWT }}" | jq -r .token \
|
||||
)
|
||||
gh api /repos/saleor/saleor-cloud-deployments/dispatches \
|
||||
--input - <<< '{
|
||||
"event_type": "open-release-pull-request",
|
||||
"client_payload": {
|
||||
"project": "DASHBOARD",
|
||||
"environment": "SANDBOX",
|
||||
"version": "${{ github.event.inputs.git_ref || github.ref_name }}"
|
||||
}
|
||||
}'
|
||||
|
||||
- name: Notify Slack
|
||||
if: ${{ always() }}
|
||||
env:
|
||||
JOB_DEPLOYMENT_KIND: staging
|
||||
JOB_STATUS: ${{ job.status }}
|
||||
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_CLOUD_DEPLOYMENTS_WEBHOOK_URL }}
|
||||
JOB_TITLE: "Dashboard deployment to ${{ env.ENVIRONMENT }}"
|
||||
run: |
|
||||
python3 ./.github/workflows/notify/notify-slack.py
|
Loading…
Reference in a new issue