-
Notifications
You must be signed in to change notification settings - Fork 1
68 lines (67 loc) · 2.38 KB
/
promote-any.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# Configuring target env
name: Prmoting app manually
on:
workflow_dispatch:
inputs:
oc_env_suffix:
description: The Env suffic of oc name space
required: true
type: choice
options:
- dev
- test
- production
env:
CLUSTER: https://api.silver.devops.gov.bc.ca:6443
AUTH_TOKEN: ${{ secrets.AUTH_TOKEN_OCP4 }}
BUILD_REF: ${{ github.base_ref }}
ENV_PREFIX: ${{ inputs.oc_env_suffix }}
NAMESPACE_DEV: ${{ vars.NAMESPACE_DEV }}
NAMESPACE_TEST: ${{ vars.NAMESPACE_TEST }}
NAMESPACE_PROD: ${{ vars.NAMESPACE_PROD }}
SOAM_CLIENT_ID_DEV: ${{ vars.SOAM_CLIENT_ID_DEV }}
SOAM_CLIENT_SECRET_DEV: ${{ secrets.SOAM_CLIENT_SECRET_DEV }}
SOAM_CLIENT_ID_TEST: ${{ vars.SOAM_CLIENT_ID_TEST }}
SOAM_CLIENT_SECRET_TEST: ${{ secrets.SOAM_CLIENT_SECRET_TEST }}
SOAM_CLIENT_ID_PROD: ${{ vars.SOAM_CLIENT_ID_PROD }}
SOAM_CLIENT_SECRET_PROD: ${{ secrets.SOAM_CLIENT_SECRET_PROD }}
jobs:
api:
name: Openshift Promote app
runs-on: ubuntu-latest
concurrency: ci-config-${{ inputs.oc_env_suffix }}
timeout-minutes: 20
environment:
name: ${{ inputs.oc_env_suffix }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Setup Dynamic env vars
working-directory: './tools'
run: |
echo "PUBLIC_HOST=$(make get-ui-url)" >> $GITHUB_ENV
echo "OC_NAMESPACE=$(make get-oc-namespace)" >> $GITHUB_ENV
- name: Tag build and deploy application
working-directory: './tools'
run: |
oc login --token="$AUTH_TOKEN" --server="$CLUSTER"
echo Env prefix: $ENV_PREFIX
make print-status
make init-api-sec
make init-api-config
make promote-api
make deploy-api
make init-web
make promote-web
make deploy-web
- name: Create Route
working-directory: './tools'
run: |
oc login --token="$AUTH_TOKEN" --server="$CLUSTER"
echo Creating route with ${{ env.PUBLIC_HOST }}
oc --namespace=${{ env.OC_NAMESPACE }} process -f openshift/public-route.yml \
-p NAME=web-ecc-iosas \
-p PUBLIC_HOST=${{ env.PUBLIC_HOST }} \
-p CERTIFICATE="${{ secrets.CERT }}" \
-p CA_CERT="${{ secrets.CA_CERT }}" \
-p PRIVATE_KEY="${{ secrets.PRIV_KEY }}" | oc --namespace=${{ env.OC_NAMESPACE }} apply -f -