-
Notifications
You must be signed in to change notification settings - Fork 12
97 lines (97 loc) · 3.46 KB
/
buildTestPublishContainerDeploy.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
name: buildTestPublishContainerDeploy
on:
push:
branches:
- main
release:
types:
- published
pull_request:
workflow_dispatch:
env:
notifyBCContainerTag: latest
jobs:
install-build-lint-and-test:
runs-on: ubuntu-latest
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- uses: actions/setup-node@v4
with:
node-version: ${{ vars.NODE_VERSION }}
- name: Install, build, lint and test:e2e 🔧
run: |
npm install
npm run build
npm run lint
npm run test:e2e
publish-container:
if: ${{ github.repository == 'bcgov/NotifyBC' && github.event_name != 'pull_request' }}
needs: install-build-lint-and-test
runs-on: ubuntu-latest
steps:
- name: Update notifyBCContainerTag for tags
if: ${{ startsWith(github.ref, 'refs/tags/') }}
run: echo notifyBCContainerTag=$(echo $GITHUB_REF | cut -d / -f 3 | cut -d v -f 2- | cut -d . -f 1,2) >> $GITHUB_ENV
- name: Update notifyBCContainerTag for branches
if: ${{ startsWith(github.ref, 'refs/heads/') && github.ref != 'refs/heads/main' }}
run: echo notifyBCContainerTag=$(echo $GITHUB_REF | cut -d / -f 3) >> $GITHUB_ENV
- name: Save $notifyBCContainerTag to file
run: |
echo $notifyBCContainerTag > notifyBCContainerTag.txt
- name: Upload notifyBCContainerTag
if: ${{ startsWith(github.ref, 'refs/heads/') }}
uses: actions/upload-artifact@v4
with:
name: notifyBCContainerTag
path: notifyBCContainerTag.txt
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.CR_PAT }}
- name: Publish Container 🚀
uses: docker/build-push-action@v6
with:
push: true
tags: ghcr.io/bcgov/notify-bc:${{ env.notifyBCContainerTag }}
build-args: nodeVersion=${{ vars.NODE_VERSION }}
deploy:
if: ${{ github.repository == 'bcgov/NotifyBC' && github.event_name == 'push' }}
needs: publish-container
runs-on: ubuntu-latest
steps:
- name: Checkout 🛎️
uses: actions/checkout@v4
with:
persist-credentials: false
- name: Decrypt values.ocp4.dev.yaml.gpg
run: ./.github/scripts/decrypt_secret.sh
env:
GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}
- name: Install oc
uses: redhat-actions/oc-installer@v1
- name: Authenticate to OCP4 and set context
uses: redhat-actions/oc-login@v1
with:
openshift_server_url: ${{ secrets.OPENSHIFT_SERVER_URL }}
openshift_token: ${{ secrets.OPENSHIFT_API_TOKEN }}
namespace: ${{ secrets.OPENSHIFT_PROJECT }}-dev
- name: Download notifyBCContainerTag
uses: actions/download-artifact@v4
with:
name: notifyBCContainerTag
- name: helm upgrade 🚀
run: |
export notifyBCContainerTag=`cat notifyBCContainerTag.txt`
helm upgrade -f helm/platform-specific/openshift.yaml \
-f .github/values.ocp4.dev.yaml --set \
image.tag="$notifyBCContainerTag" `helm ls -q` helm
oc get deployment -o name | xargs oc rollout restart