forked from pinkycollie/deaf-first-platform
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcloudbuild-deploy.yaml
More file actions
115 lines (104 loc) · 3.37 KB
/
Copy pathcloudbuild-deploy.yaml
File metadata and controls
115 lines (104 loc) · 3.37 KB
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
# Cloud Build configuration for deployment on release tags
# Deploys services to Cloud Run when a version tag is pushed
steps:
# Install dependencies
- name: 'node:20'
id: 'install-dependencies'
entrypoint: 'npm'
args: ['ci']
# Build all services
- name: 'node:20'
id: 'build'
entrypoint: 'npm'
args: ['run', 'build']
waitFor: ['install-dependencies']
# Build and push Docker images
- name: 'gcr.io/cloud-builders/docker'
id: 'build-images'
args:
- 'build'
- '-t'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-deafauth:${TAG_NAME}'
- '-f'
- 'services/deafauth/Dockerfile'
- '.'
waitFor: ['build']
# Deploy to Cloud Run - DeafAUTH
- name: 'gcr.io/google.com/cloudsdktool/cloud-sdk'
id: 'deploy-deafauth'
entrypoint: 'gcloud'
args:
- 'run'
- 'deploy'
- '${_PROJECT_NAME}-deafauth-functions'
- '--image'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-deafauth:${TAG_NAME}'
- '--region'
- '${_REGION}'
- '--platform'
- 'managed'
- '--allow-unauthenticated'
- '--service-account'
- '${_SERVICE_ACCOUNT}'
waitFor: ['build-images']
# Deploy to Cloud Run - PinkSync
- name: 'gcr.io/google.com/cloudsdktool/cloud-sdk'
id: 'deploy-pinksync'
entrypoint: 'gcloud'
args:
- 'run'
- 'deploy'
- '${_PROJECT_NAME}-pinksync-api'
- '--image'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-pinksync:${TAG_NAME}'
- '--region'
- '${_REGION}'
- '--platform'
- 'managed'
- '--allow-unauthenticated'
- '--service-account'
- '${_SERVICE_ACCOUNT}'
waitFor: ['build-images']
# Deploy to Cloud Run - FibonRose
- name: 'gcr.io/google.com/cloudsdktool/cloud-sdk'
id: 'deploy-fibonrose'
entrypoint: 'gcloud'
args:
- 'run'
- 'deploy'
- '${_PROJECT_NAME}-fibonrose-api'
- '--image'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-fibonrose:${TAG_NAME}'
- '--region'
- '${_REGION}'
- '--platform'
- 'managed'
- '--allow-unauthenticated'
- '--service-account'
- '${_SERVICE_ACCOUNT}'
waitFor: ['build-images']
# Run post-deployment tests
- name: 'node:20'
id: 'smoke-tests'
entrypoint: 'npm'
args: ['run', 'test:smoke']
env:
- 'NODE_ENV=production'
waitFor: ['deploy-deafauth', 'deploy-pinksync', 'deploy-fibonrose']
# Build images
images:
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-deafauth:${TAG_NAME}'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-pinksync:${TAG_NAME}'
- '${_REGION}-docker.pkg.dev/${PROJECT_ID}/${_ARTIFACT_REGISTRY}/${_PROJECT_NAME}-fibonrose:${TAG_NAME}'
# Build timeout
timeout: '2400s'
# Logging options
options:
logging: CLOUD_LOGGING_ONLY
machineType: 'N1_HIGHCPU_8'
# Substitutions
substitutions:
_REGION: 'us-central1'
_ARTIFACT_REGISTRY: 'deaf-first-production-containers'
_PROJECT_NAME: 'deaf-first-production'
_SERVICE_ACCOUNT: 'cloudbuild@deaf-first-production.iam.gserviceaccount.com'