-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
125 lines (110 loc) · 5.07 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
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
124
125
SHELL := /usr/bin/env bash
__FILENAME := $(lastword $(MAKEFILE_LIST))
__DIRNAME := $(abspath $(realpath $(lastword $(MAKEFILE_LIST)))/../)
help: ## Show this help.
@sed -ne '/@sed/!s/## //p' $(MAKEFILE_LIST)
.PHONY: release
release: ## Tag a release using release-it
release:
@yarn
@yarn release-it
.PHONY: lint_chart
lint_chart: ## Checks the configured helm chart template definitions against the remote schema
lint_chart:
@set -euo pipefail; \
helm dep up ./helm/cas-registration; \
helm template -f ./helm/cas-registration/values-dev.yaml cas-registration ./helm/cas-registration --validate;
check_environment: ## Making sure the environment is properly configured for helm
check_environment:
@set -euo pipefail; \
if [ -z '$(OBPS_NAMESPACE_PREFIX)' ]; then \
echo "OBPS_NAMESPACE_PREFIX is not set"; \
exit 1; \
fi; \
if [ -z '$(ENVIRONMENT)' ]; then \
echo "ENVIRONMENT is not set"; \
exit 1; \
fi; \
verify_postgres_deployment: ## Making sure the environment is properly configured for helm
verify_postgres_deployment:
@set -euo pipefail; \
if ! helm status --namespace $(NAMESPACE) cas-obps-postgress; then \
echo "Postgres is not deployed to $(NAMESPACE)." \
exit 1; \
fi; \
.PHONY: install
install: ## Installs the BCIERS helm chart on the OpenShift cluster
install: check_environment
install:
install: GIT_SHA1=$(shell git rev-parse HEAD)
install: IMAGE_TAG=$(GIT_SHA1)
install: NAMESPACE=$(OBPS_NAMESPACE_PREFIX)-$(ENVIRONMENT)
install: CHART_DIR=./helm/cas-bciers
install: CHART_INSTANCE=cas-bciers
install: HELM_OPTS=--atomic --wait-for-jobs --timeout 2400s --namespace $(NAMESPACE) \
--set defaultImageTag=$(IMAGE_TAG) \
--set download-dags.dagConfiguration="$$dagConfig" \
--values $(CHART_DIR)/values-$(ENVIRONMENT).yaml
install:
@set -euo pipefail; \
dagConfig=$$(echo '{"org": "bcgov", "repo": "cas-registration", "ref": "$(GIT_SHA1)", "path": "dags/cas_bciers_dags.py"}' | base64 -w0); \
helm dep up $(CHART_DIR); \
if ! helm status --namespace $(NAMESPACE) cas-obps-postgres; then \
echo "ERROR: Postgres is not deployed to $(NAMESPACE)."; \
elif ! helm status --namespace $(NAMESPACE) $(CHART_INSTANCE); then \
echo 'Installing the application'; \
helm install $(HELM_OPTS) $(CHART_INSTANCE) $(CHART_DIR); \
else \
helm upgrade $(HELM_OPTS) $(CHART_INSTANCE) $(CHART_DIR); \
fi;
.PHONY: install_reg1
install_reg1: ## Installs the helm Registration part 1 chart on the OpenShift cluster
install_reg1: check_environment
install_reg1:
install_reg1: GIT_SHA1=$(shell git rev-parse HEAD)
install_reg1: IMAGE_TAG=$(GIT_SHA1)
install_reg1: NAMESPACE=$(OBPS_NAMESPACE_PREFIX)-$(ENVIRONMENT)
install_reg1: CHART_DIR=./helm/cas-registration
install_reg1: CHART_INSTANCE=cas-registration
install_reg1: HELM_OPTS=--atomic --wait-for-jobs --timeout 2400s --namespace $(NAMESPACE) \
--set defaultImageTag=$(IMAGE_TAG) \
--values $(CHART_DIR)/values-$(ENVIRONMENT).yaml
install_reg1:
@set -euo pipefail; \
helm dep up $(CHART_DIR); \
if ! helm status --namespace $(NAMESPACE) cas-obps-postgres; then \
echo "ERROR: Postgres is not deployed to $(NAMESPACE)."; \
elif ! helm status --namespace $(NAMESPACE) $(CHART_INSTANCE); then \
echo 'Installing the application'; \
helm install $(HELM_OPTS) $(CHART_INSTANCE) $(CHART_DIR); \
else \
helm upgrade $(HELM_OPTS) $(CHART_INSTANCE) $(CHART_DIR); \
fi;
.PHONY: generate_credentials
generate_credentials:
./scripts/generate-gcloud-credentials.sh $(service_account)
.PHONY: create_state_buckets
create_state_buckets:
./scripts/create-state-buckets.sh $(openshift_nameplate) "ggl-cas-storage"
.PHONY: perf_test
perf_test: ## run performance tests with k6
perf_test: SERVER_HOST=http://127.0.0.1:8000
perf_test: SERVER_API_ROUTE=/api/registration
perf_test: SERVER_ROUTE=$(SERVER_HOST)$(SERVER_API_ROUTE)
perf_test:
@k6 -e SERVER_HOST=$(SERVER_ROUTE) run bciers/apps/registration1/tests/performance/script.js --out csv=k6_results/test_results.csv
.PHONY: perf_test_frontend
perf_test_frontend: ## run frontend performance tests with k6
perf_test_frontend: APP_HOST=http://localhost:3000
perf_test_frontend:
@k6 -e APP_HOST=$(APP_HOST) run bciers/apps/registration1/tests/performance/frontend_script.js --out csv=k6_results/test_results_frontend.csv
# include .env.devops
# .PHONY: bootstrap_terraform
# bootstrap_terraform:
# ./devops/scripts/generate-gcloud-credentials.sh $(SERVICE_ACCOUNT)
# ./devops/scripts/create-kubernetes-secret-admin-sa.sh $(OPENSHIFT_NAMESPACE)
# ./devops/scripts/create-state-bucket.sh $(OPENSHIFT_NAMESPACE) "ggl-cas-storage"
# ./devops/scripts/create-terraform-backend.sh $(OPENSHIFT_NAMEPLATE) $(OPENSHIFT_ENVIRONMENT)
# oc create secret generic gcp-credentials-secret --from-file=sa_json=./credentials.json --from-literal=gcp_project_id="ggl-cas-storage" --from-literal=openshift_namespace=$(OPENSHIFT_NAMESPACE) --from-literal=openshift_nameplate=$(OPENSHIFT_NAMEPLATE) --from-literal=openshift_environment=$(OPENSHIFT_ENVIRONMENT) --from-file=tf_backend=$(OPENSHIFT_ENVIRONMENT).gcs.tfbackend
# @mv $(OPENSHIFT_ENVIRONMENT).gcs.tfbackend ./devops
# @mv credentials.json ./devops