forked from google-github-actions/deploy-cloudrun
123 lines (108 loc) · 3.66 KB
/
deploy-cloudrun-credentials-it.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
121
122
123
name: deploy-cloudrun Credentials Integration
on:
push:
branches:
- 'main'
pull_request:
jobs:
gcloud:
name: with setup-gcloud
if: ${{ github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name }}
runs-on: ubuntu-latest
steps:
- id: service
run: echo ::set-output name=service::run-gcloud-$GITHUB_SHA
- uses: actions/checkout@v2
- uses: actions/setup-node@master
with:
node-version: 12.x
- run: |-
npm install
npm run build
- name: Set up authentication
uses: google-github-actions/setup-gcloud@master
with:
service_account_key: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_B64 }}
export_default_credentials: true
- id: deploy
uses: ./
with:
image: gcr.io/cloudrun/hello
service: ${{ steps.service.outputs.service }}
- name: Integration Tests
run: npm run e2e-tests
env:
URL: ${{ steps.deploy.outputs.url }}
b64_json:
name: with base64 creds
if: ${{ github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name }}
runs-on: ubuntu-latest
steps:
- id: service
run: echo ::set-output name=service::run-b64-$GITHUB_SHA
- uses: actions/checkout@v2
- uses: actions/setup-node@master
with:
node-version: 12.x
- run: |-
npm install
npm run build
- id: deploy
uses: ./
with:
credentials: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_B64 }}
image: gcr.io/cloudrun/hello
service: ${{ steps.service.outputs.service }}
- uses: google-github-actions/setup-gcloud@master # Set up ADC to make authenticated request to service
with:
service_account_key: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_B64 }}
export_default_credentials: true
- name: Integration Tests
run: npm run e2e-tests
env:
URL: ${{ steps.deploy.outputs.url }}
json:
name: with json creds
if: ${{ github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name }}
runs-on: ubuntu-latest
steps:
- id: service
run: echo ::set-output name=service::run-json-$GITHUB_SHA
- uses: actions/checkout@v2
- uses: actions/setup-node@master
with:
node-version: 12.x
- run: |-
npm install
npm run build
- id: deploy
uses: ./
with:
credentials: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_JSON }}
image: gcr.io/cloudrun/hello
service: ${{ steps.service.outputs.service }}
- uses: google-github-actions/setup-gcloud@master # Set up ADC to make authenticated request to service
with:
service_account_key: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_B64 }}
export_default_credentials: true
- name: Integration Tests
run: npm run e2e-tests
env:
URL: ${{ steps.deploy.outputs.url }}
cleanup:
name: Clean Up
if: ${{ (github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name) && always() }}
runs-on: ubuntu-latest
needs: [json, gcloud, b64_json]
steps:
- uses: google-github-actions/setup-gcloud@master
with:
service_account_key: ${{ secrets.DEPLOY_CLOUDRUN_SA_KEY_B64 }}
project_id: ${{ secrets.DEPLOY_CLOUDRUN_PROJECT_ID }}
- name: Delete services
run: |-
gcloud config set run/platform managed
gcloud config set run/region us-central1
gcloud run services delete run-json-$GITHUB_SHA --quiet
gcloud run services delete run-b64-$GITHUB_SHA --quiet
gcloud run services delete run-gcloud-$GITHUB_SHA --quiet