-
-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathMakefile
84 lines (71 loc) · 3 KB
/
Makefile
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
.PHONY: echo-exports test test-install client-server backend-server build-www deploy-config deploy-www deploy-data deploy-server deploy
# default to sourcemaps.io production values
#
GCLOUD_FN_NAME=validateGeneratedFile
GCLOUD_REGION=us-central1
GCLOUD_VALIDATE_URL=https://${GCLOUD_REGION}-${GCLOUD_PROJECT}.cloudfunctions.net/${GCLOUD_FN_NAME}
GCLOUD_STORAGE_URL=https://storage.googleapis.com/${GCLOUD_DATA_BUCKET}
LOCAL_VALIDATE_URL=http://127.0.0.1:3001/${GCLOUD_FN_NAME}
echo-exports:
@echo "GCLOUD_PROJECT: ${GCLOUD_PROJECT}"
@echo "GCLOUD_REGION: ${GCLOUD_REGION}"
@echo "GCLOUD_FN_NAME: ${GCLOUD_FN_NAME}"
@echo "GCLOUD_APP_BUCKET: ${GCLOUD_APP_BUCKET}"
@echo "GCLOUD_DATA_BUCKET: ${GCLOUD_DATA_BUCKET}"
@echo "GCLOUD_WWW_BUCKET: ${GCLOUD_WWW_BUCKET}"
# Run unit tests
test: test-install
npm run lint
npm test
test-install: echo-exports
npm install --legacy-peer-deps
npm install --legacy-peer-deps --prefix ./server
npm install --prefix ./client
# Launch a local development server for working on the
# React www app (points at deployed/production validation fn)
client-server: test-install
REACT_APP_VALIDATE_URL=${LOCAL_VALIDATE_URL} REACT_APP_STORAGE_URL=${GCLOUD_STORAGE_URL} \
npm run dev --prefix ./client
backend-server: test-install deploy-data
npm run start --prefix ./server
#------------------------------------------------------------------
# Deploy recipes (to Google Cloud Platform)
#
# NOTE: If you're doing local development, you can stop here and
# just use the 3 commands above (test, test-install, server).
#
# Required environment variables for deployment:
# GCLOUD_PROJECT - project id
# GCLOUD_APP_BUCKET - google cloud functions staging bucket id
# GCLOUD_DATA_BUCKET - report storage (JSON) bucket id
# GCLOUD_WWW_BUCKET - static website deployment bucket id
# Create a production build of the React www app intended
# for deployment (see deploy-www)
build-www:
npm install --prefix ./client
REACT_APP_VALIDATE_URL=${GCLOUD_VALIDATE_URL} REACT_APP_STORAGE_URL=${GCLOUD_STORAGE_URL} \
npm run build --prefix ./client
deploy-config: echo-exports
gcloud config set project ${GCLOUD_PROJECT}
echo '{"PROJECT":"${GCLOUD_PROJECT}","STORAGE_BUCKET":"${GCLOUD_DATA_BUCKET}","SENTRY_DSN":"${SENTRY_DSN}"}' > server/config.json
# Deploy static website
deploy-www: deploy-config build-www
gsutil -m rsync -R -d client/build gs://${GCLOUD_WWW_BUCKET}
gsutil web set -e index.html gs://${GCLOUD_WWW_BUCKET}
gsutil acl ch -u AllUsers:R gs://${GCLOUD_WWW_BUCKET}
# Deploy reports (basically just set perms)
deploy-data: deploy-config
gsutil acl ch -u AllUsers:R gs://${GCLOUD_DATA_BUCKET}
gsutil cors set server/cors.json gs://${GCLOUD_DATA_BUCKET}
# Deploy server[less] code
deploy-server: deploy-config
npm install --prefix ./server
npm run build
gcloud functions deploy ${GCLOUD_FN_NAME} \
--source server \
--stage-bucket ${GCLOUD_APP_BUCKET} \
--trigger-http \
--verbosity debug \
--runtime nodejs18
# Deploy all
deploy: build-www deploy-config deploy-server deploy-data deploy-www