-
Notifications
You must be signed in to change notification settings - Fork 1
120 lines (104 loc) · 4.11 KB
/
deploy-pr.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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# This action will create the azure resources, github secret, github environment, and deploy the app when a PR is opened, reopened, or synchronized.
# https://github.com/Azure/webapps-deploy/issues/28
name: Deploy PR
on:
pull_request:
types: [opened, reopened, synchronize]
branches: main
env:
AZURE_WEBAPP_NAME: gccollab-dev-pr-${{ github.event.number }}
AZURE_WEBAPP_PACKAGE_PATH: './dist/gccollab-frontend'
NODE_VERSION: '18.13.0'
ACCESS_TOKEN: ${{ secrets.BOT_ACCESS_TOKEN }}
LOCATION: canadaeast
SECRET_NAME: PR_${{ github.event.number }}
jobs:
setup:
name: Deploy Bicep
runs-on: ubuntu-latest
if: ${{ !contains(github.event.pull_request.title, vars.IGNORE_DEPLOY) }}
steps:
- uses: actions/checkout@v3
- uses: azure/login@v1
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: Create Resources
uses: azure/CLI@v1
with:
azcliversion: 2.30.0
inlineScript: |
if [[ ${{ github.event.action }} != "synchronize" ]]; then
az deployment sub create -l ${{ env.LOCATION }} -f ./.bicep/pr-instance-setup.bicep --parameters prNumber=${{ github.event.number }} location=${{ env.LOCATION }}
else
echo "The Azure resources have already been created."
fi
store:
name: Store Publishing Profile
runs-on: ubuntu-latest
needs: setup
if: ${{ !contains(github.event.pull_request.title, vars.IGNORE_DEPLOY) }}
steps:
- name: Azure Login
uses: azure/login@v1
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: Get Publishing Profile
id: get-publishing-profile
run: |
profile=$(az webapp deployment list-publishing-profiles --resource-group ${{ env.AZURE_WEBAPP_NAME }} --name ${{ env.AZURE_WEBAPP_NAME }} --xml | sed -e 's|\"<|<|g' | sed -e 's|>\"|>|g' | sed -e 's|\\"|"|g' | sed -e 's|\\\\|\\|g') > /dev/null
echo "::set-output name=profile::$profile" > /dev/null
- name: GitHub Auth Login
shell: bash
run: gh auth login --with-token <<< ${{ env.ACCESS_TOKEN }}
- uses: actions/checkout@v3
- name: Create Secret
run: gh secret set "${{ env.SECRET_NAME }}" --body "${{ env.PROFILE }}"
env:
PROFILE: ${{ steps.get-publishing-profile.outputs.profile }}
create-environment:
name: Create Environment
runs-on: ubuntu-latest
needs: [setup, store]
if: ${{ !contains(github.event.pull_request.title, vars.IGNORE_DEPLOY) }}
steps:
- name: Create Environment
shell: bash
run: |
if [[ ${{ github.event.action }} != "synchronize" ]]; then
curl -X POST "https://api.github.com/repos/gctools-outilsgc/gccollab-frontend/environments" \
-H "Authorization: token ${{ env.ACCESS_TOKEN }}" \
-H "Accept: application/vnd.github.v3+json" \
-d "{\"name\":\"PR ${{ github.event.number }}\"}"
else
echo "Environment has already been created."
fi
build-test-and-deploy:
name: Build, Test and Deploy
runs-on: windows-latest
needs: [setup, store, create-environment]
if: ${{ !contains(github.event.pull_request.title, vars.IGNORE_DEPLOY) }}
environment:
name: PR ${{ github.event.number }}
url: https://${{ env.AZURE_WEBAPP_NAME }}.azurewebsites.net/
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v1
with:
node-version: ${{ env.NODE_VERSION }}
- name: Install
run: npm install
- name: Build
run: npm run build-pr --if-present
- name: Test
run: npm run test --if-present -- --watch=false --browsers=ChromeHeadless
- name: Azure Login
uses: azure/login@v1
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: 'Deploy to Azure WebApp'
uses: azure/webapps-deploy@v1
with:
app-name: ${{ env.AZURE_WEBAPP_NAME }}
publish-profile: ${{ secrets[env.SECRET_NAME] }}
package: ${{ env.AZURE_WEBAPP_PACKAGE_PATH }}