-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathMakefile
157 lines (128 loc) · 5.72 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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
.PHONY: build reset-dev-env migrate be-up fe-up up c rails-console rails-console-exec e2e-setup e2e-setup-and-up e2e-run-test e2e-ci-env-setup e2e-ci-env-setup-and-up e2e-ci-env-run-test ci-regenerate-templates ci-trigger-build ci-run-e2e release_pr
# You can run this file with `make` command:
# make reset-dev-env
# make up
# All commands from this file should work in bash too after:
# 1. replacing $$ with $
# 2. replacing variables in ${} with some values, so `-u ${CIRCLE_CI_TOKEN}:` becomes `-u XXX:`
release_pr:
@./scripts/create_release_pr.sh
# =================
# Dev env
# =================
build:
docker compose build
cd front && npm install
reset-dev-env:
# -v removes volumes with all the data inside https://docs.docker.com/compose/reference/down/
docker compose down -v || true # do not exit on error (some networks may be present, volumes may be used, which is often fine)
make build
# https://citizenlabco.slack.com/archives/C016C2EHURY/p1644234622002569
docker compose run --rm web "bin/rails db:create && bin/rails db:reset"
docker compose run --rm -e RAILS_ENV=test web bin/rails db:drop db:create db:schema:load
migrate:
docker compose run --rm web bin/rails db:migrate cl2back:clean_tenant_settings email_campaigns:assure_campaign_records fix_existing_tenants:update_permissions cl2back:clear_cache_store email_campaigns:remove_deprecated
be-up:
docker compose up
fe-up:
cd front && npm start
up:
make -j 2 be-up fe-up
# For testing different SSO methods
be-up-claveunica:
docker compose down
BASE_DEV_URI=https://claveunica-h2dkc.loca.lt docker compose up -d
lt --print-requests --port 3000 --subdomain claveunica-h2dkc
be-up-nemlogin:
docker compose down
BASE_DEV_URI=https://nemlogin-k3kd.loca.lt docker compose up -d
lt --print-requests --port 3000 --subdomain nemlogin-k3kd
be-up-idaustria:
docker compose down
BASE_DEV_URI=https://idaustria-g3fy.loca.lt docker compose up -d
lt --print-requests --port 3000 --subdomain idaustria-g3fy
be-up-keycloak:
docker compose down
BASE_DEV_URI=https://keycloak-r3tyu.loca.lt docker compose up -d
lt --print-requests --port 3000 --subdomain keycloak-r3tyu
# Run it with:
# make c
# # or
# make rails-console
c rails-console:
docker compose run --rm web bin/rails c
# Runs rails console in an existing web container. May be useful if you need to access localhost:4000 in the console.
# E.g., this command works in this console `curl http://localhost:4000`
rails-console-exec:
docker exec -it "$$(docker ps | awk '/cl-back-web/ {print $$1}' | head -1)" bin/rails c
# search_path=localhost specifies the schema of localhost tenant
psql:
docker compose run -it -e PGPASSWORD=postgres -e PGOPTIONS="--search_path=localhost" postgres psql -U postgres -h postgres -d cl2_back_development
# Run it with:
# make copy-paste-code-entity source=initiative_resubmitted_for_review target=new_cosponsor_added
# See back/bin/copy_paste_code_entity for details.
copy-paste-code-entity:
back/bin/copy_paste_code_entity ${source} ${target}
blint back-lint-autocorrect:
docker compose run web bundle exec rubocop -P --format simple --autocorrect
# Usage example:
# make r file=spec/models/idea_spec.rb
r rspec:
docker compose run --rm web bin/rspec ${file}
# Usage example:
# make feature-toggle feature=initiative_cosponsors enabled=true
feature-toggle:
docker compose run web "bin/rails runner \"enabled = ${enabled}; feature = '${feature}'; Tenant.find_by(host: 'localhost').switch!; c = AppConfiguration.instance; c.settings['${feature}'] ||= {}; c.settings['${feature}']['allowed'] = ${enabled}; c.settings['${feature}']['enabled'] = ${enabled}; c.save!\""
# =================
# E2E tests
# =================
#
# https://www.notion.so/citizenlab/Testing-253d0c3cd99841a59929f7f615179935?pvs=4#6a0fc23d220c4afeb90bbd0cb7dbc0f5
# After running this command, start the dev servers as usual (make up)
e2e-setup:
make build
docker compose run --rm web bin/rails db:drop db:create db:schema:load
docker compose run --rm web bin/rails cl2_back:create_tenant[localhost,e2etests_template]
e2e-setup-and-up:
make e2e-setup
make up
# Run it with:
# make e2e-run-test spec=cypress/e2e/about_page.cy.ts
# # or specify an entire folder
# make e2e-run-test spec=cypress/e2e/project_description_builder/sections
e2e-run-test:
cd front && \
npm run cypress:run -- --config baseUrl=http://localhost:3000 --spec ${spec}
# =================
# CircleCI
# =================
#
# 1. Generate your personal API token:
# go to CircleCI's user settings > Personal API Tokens https://app.circleci.com/settings/user/tokens
# 2. Export it in your shell:
# e.g., add this line to your .bashrc or .zshrc
# export CIRCLE_CI_TOKEN=XXX
ci-regenerate-templates:
curl \
--request POST \
-u ${CIRCLE_CI_TOKEN}: \
--url https://circleci.com/api/v2/project/github/CitizenLabDotCo/citizenlab/pipeline \
--header 'content-type: application/json' \
--data '{"branch": "production", "parameters": {"templates": true, "trigger": false }}'
# Triggers a build for the current branch.
# Also, builds images for the Epic platform.
ci-build:
curl \
--request POST \
-u ${CIRCLE_CI_TOKEN}: \
--url https://circleci.com/api/v2/project/github/CitizenLabDotCo/citizenlab/pipeline \
--header 'content-type: application/json' \
--data "{\"branch\": \"$$(git branch --show-current)\",\"parameters\": {\"trigger\": false, \"back\": true, \"front\": true } }"
ci-e2e:
curl \
--request POST \
-u ${CIRCLE_CI_TOKEN}: \
--url https://circleci.com/api/v2/project/github/CitizenLabDotCo/citizenlab/pipeline \
--header 'content-type: application/json' \
--data "{\"branch\": \"$$(git branch --show-current)\",\"parameters\": {\"e2e\": true } }"
$(info You can check the status of the build here: https://app.circleci.com/pipelines/github/CitizenLabDotCo/citizenlab)