-
-
Notifications
You must be signed in to change notification settings - Fork 23
/
Makefile
213 lines (154 loc) · 7.51 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
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
# to suppress the path translation in Windows
export MSYS_NO_PATHCONV=1
ifeq ($(findstring cmd.exe,$(SHELL)),cmd.exe)
$(error "We do not suppport using cmd.exe on Windows, please run in a 'git bash' console")
endif
# use bash everywhere !
SHELL := /bin/bash
ENV_FILE ?= .env
# load env variables
# also takes into account envrc (direnv file)
ifneq (,$(wildcard ./${ENV_FILE}))
-include ${ENV_FILE}
-include .envrc
export
endif
export DOCKER_BUILDKIT=1
export COMPOSE_DOCKER_CLI_BUILD=1
DOCKER_COMPOSE=docker compose --env-file=${ENV_FILE}
# tweak some config to avoid port conflicts
DOCKER_COMPOSE_TEST=COMPOSE_PROJECT_NAME=test_taxonomy NEO4J_ADMIN_EXPOSE=127.0.0.1:7475 NEO4J_BOLT_EXPOSE=127.0.0.1:7688 docker compose --env-file=${ENV_FILE}
#------------#
# local dev #
#------------#
install: ## Install dependencies
@echo "🍜 Installing dependencies"
cd taxonomy-editor-frontend && npm install
cd backend && poetry install
cd parser && poetry install
@echo "🍜 Project setup done"
local_frontend: ## Run the frontend locally
@echo "🍜 Running frontend (ctrl+C to stop)"
cd taxonomy-editor-frontend && VITE_APP_API_URL="http://localhost:8080/" npm start
local_backend: ## Run the backend locally
@echo "🍜 Running backend (ctrl+C to stop)"
cd backend && poetry run uvicorn editor.api:app --host 127.0.0.1 --port 8080 --env-file=../.env --reload
databases: ## Start the databases Docker container for local development
@echo "🍜 Running neo4j (ctrl+C to stop)"
${DOCKER_COMPOSE} up --build neo4j
add_local_test_data: ## Add test data to the local database
@echo "🍜 Adding test data to the database"
cd backend && poetry run python sample/load.py sample/test-neo4j.json
local_lint: local_backend_lint local_frontend_lint local_config_lint ## Run lint on local code
local_backend_lint: ## Run lint on local backend code
@echo "🍜 Linting python code"
cd backend && poetry run isort --skip .venv .
cd backend && poetry run black --exclude=.venv .
local_frontend_lint: ## Run lint on local frontend code
@echo "🍜 Linting react code"
cd taxonomy-editor-frontend && npm run lint
local_config_lint: ## Run on lint configuration files
@echo "🍜 Linting configuration files"
npm run lint
local_generate_sdk: ## Generate client SDK from OpenAPI spec
@echo "🍜 Generating client SDK from OpenAPI spec"
cd backend && make generate_spec
cd taxonomy-editor-frontend && npm run generate:api
local_quality: local_backend_quality local_frontend_quality local_config_quality ## Run lint on local code
local_backend_quality: ## Run lint on local backend code
@echo "🍜 Quality python code checks"
cd backend && poetry run isort --check-only --skip .venv .
cd backend && poetry run black --check --exclude=.venv .
cd backend && poetry run flake8 --exclude=.venv .
local_frontend_quality: ## Run lint on local frontend code
@echo "🍜 Quality react code checks"
cd taxonomy-editor-frontend && npm run lint:check
local_config_quality: ## Run on lint configuration files
@echo "🍜 Quality configuration files checks"
npm run lint:check
#------------#
# dev setup #
#------------#
build: ## Build docker images
@echo "🍜 Building docker images"
${DOCKER_COMPOSE} build ${args}
@echo "🍜 Project setup done"
backend_poetry_update: ## Update poetry.lock file
@echo "🍜 Updating poetry.lock file"
${DOCKER_COMPOSE} run --user root --rm taxonomy_api bash -c "pip install poetry==1.4.2 && poetry lock --no-update"
up: ## Run the project
@echo "🍜 Running project (ctrl+C to stop)"
@echo "🍜 The React app will be available on http://ui.taxonomy.localhost:8091"
@echo "🍜 The API will be exposed on http://api.taxonomy.localhost:8091"
@echo "🍜 The Neo4j admin console will be available on http://localhost:7474/browser/"
${DOCKER_COMPOSE} up
dev: build up ## Build and run the project
#-----------#
# dev tools #
#-----------#
generate_sdk: ## Generate client SDK from OpenAPI spec
@echo "🍜 Generating client SDK from OpenAPI spec"
${DOCKER_COMPOSE} run --rm taxonomy_api python -m openapi.generate_openapi_spec
${DOCKER_COMPOSE} run --rm taxonomy_editor_code npm run lint
${DOCKER_COMPOSE} run --rm taxonomy_node npm run generate:api
# lint code
lint: parser_lint backend_lint frontend_lint config_lint ## Run all linters
backend_lint: ## Run lint on backend code
@echo "🍜 Linting python code"
${DOCKER_COMPOSE} run --rm taxonomy_api isort .
${DOCKER_COMPOSE} run --rm taxonomy_api black .
parser_lint: ## Run lint on parser code
@echo "🍜 Linting python code"
${DOCKER_COMPOSE} run --rm -w /parser taxonomy_api isort /parser
${DOCKER_COMPOSE} run --rm -w /parser taxonomy_api black /parser
frontend_lint: ## Run lint on frontend code
@echo "🍜 Linting react code"
${DOCKER_COMPOSE} run --rm taxonomy_node npx eslint --fix src/
${DOCKER_COMPOSE} run --rm taxonomy_node npx prettier -w src/
config_lint: ## Run on lint configuration files
@echo "🍜 Linting configuration files"
${DOCKER_COMPOSE} run --rm taxonomy_editor_code npm run lint
# check code quality
quality: parser_quality backend_quality frontend_quality config_quality ## Run all quality checks
backend_quality: ## Run quality checks on backend code
@echo "🍜 Quality checks python"
${DOCKER_COMPOSE} run --rm taxonomy_api flake8 --exclude=.venv .
${DOCKER_COMPOSE} run --rm taxonomy_api isort --check-only --skip .venv .
${DOCKER_COMPOSE} run --rm taxonomy_api black --check --exclude=.venv .
parser_quality: ## Run quality checks on backend code
@echo "🍜 Quality checks python"
${DOCKER_COMPOSE} run --rm -w /parser taxonomy_api flake8 --exclude=.venv /parser
${DOCKER_COMPOSE} run --rm -w /parser taxonomy_api isort --check-only --skip .venv /parser
${DOCKER_COMPOSE} run --rm -w /parser taxonomy_api black --check --exclude=.venv /parser
frontend_quality: ## Run quality checks on frontend code
@echo "🍜 Quality checks JS"
${DOCKER_COMPOSE} run --rm taxonomy_node npx eslint --no-fix src/
${DOCKER_COMPOSE} run --rm taxonomy_node npx prettier -c src/
${DOCKER_COMPOSE} run --rm -e CI=true taxonomy_node npm run build
# restore the .empty file (if possible)
git checkout taxonomy-editor-frontend/build/.empty || true
config_quality: ## Run quality checks on configuration files
@echo "🍜 Quality checks configuration files"
${DOCKER_COMPOSE} run --rm taxonomy_editor_code npm run lint:check
tests: backend_tests ## Run all tests
backend_tests: ## Run python tests, you might provide additional arguments with args="…"
@echo "🍜 Running python tests"
${DOCKER_COMPOSE_TEST} up -d neo4j
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /parser ${args}
${DOCKER_COMPOSE_TEST} run --rm taxonomy_api pytest /code/tests ${args}
${DOCKER_COMPOSE_TEST} stop neo4j
checks: quality tests ## Run all checks (quality + tests)
#------------#
# production #
#------------#
create_external_volumes: ## Create external volumes (production only)
@echo "🍜 Creating external volumes (production only) …"
docker volume create ${COMPOSE_PROJECT_NAME}_neo4j-data
#------------#
# utils #
#------------#
.DEFAULT_GOAL := help
.PHONY: build up dev lint backend_lint frontend_lint quality backend_quality frontend_quality tests backend_tests checks create_external_volumes help
# this command will grep targets and the following ## comment will be used as description
help: ## Description of the available commands
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m\033[0m\n"} /^[$$()% a-zA-Z_-]+:.*?##/ { printf " \033[36m%-30s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)