-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
91 lines (78 loc) · 2.33 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
# Load environment variables from .env
ifneq (,$(wildcard ./.env))
include .env
export
endif
# Export default environment variables
## NOTE: you should only change these for you local environment. For other
## environments like beta or prod, set the DATABASE_URL in your .env file.
DB_USER ?= postgres
DB_PASS ?= password
DB_NAME ?= ethwaterloo
DB_HOST ?= localhost
DB_PORT ?= 5432
DATABASE_URL ?= postgres://${DB_USER}:${DB_PASS}@${DB_HOST}:${DB_PORT}/${DB_NAME}?sslmode=disable
DOCKER_CONTAINER_NAME ?= ethwaterloo-postgres
_TITLE := "\033[32m[%s]\033[0m %s\n" # Green text for "printf"
_ERROR := "\033[31m[%s]\033[0m %s\n" # Red text for "printf"
# if the CI variable is set, it automatically continues
.PHONY: confirm
confirm:
@if [[ -z "$(CI)" ]]; then \
REPLY="" ; \
read -p "⚠ Are you sure? [y/n] > " -r ; \
if [[ ! $$REPLY =~ ^[Yy]$$ ]]; then \
printf $(_ERROR) "NO" "Stopping" ; \
exit 1 ; \
else \
printf $(_TITLE) "OK" "Continuing" ; \
exit 0; \
fi \
fi
# hook to check if command exists
cmd-exists-%:
@hash $(*) > /dev/null 2>&1 || \
(echo "ERROR: '$(*)' must be installed and available on your PATH."; exit 1)
# hook to wait for Postgres to become available
wait-for-postgres: cmd-exists-psql
@until psql ${DATABASE_URL} -c '\q'; do \
echo "Postgres is unavailable - trying again"; \
sleep 1; \
done
@echo "Postgres is up and running on port ${DB_PORT}!"
# hook to initialize the postgres container
db-init: cmd-exists-docker
docker run \
--name="${DOCKER_CONTAINER_NAME}" \
-e POSTGRES_USER="${DB_USER}" \
-e POSTGRES_PASSWORD="${DB_PASS}" \
-e POSTGRES_DB="${DB_NAME}" \
-p "${DB_PORT}":5432 \
-d postgres:15-alpine \
postgres -N 1000
# create the local database
.PHONY: db-create
db-create: db-init wait-for-postgres cmd-exists-sqlx
@sqlx database create -D "${DATABASE_URL}"
# remove the local database
.PHONY: db-drop
db-drop: cmd-exists-docker
@docker kill ${DOCKER_CONTAINER_NAME}
@docker rm ${DOCKER_CONTAINER_NAME}
# show the current connection string
.PHONY: db-show
db-show:
@echo ${DATABASE_URL}
# quickly reset the local database
.PHONY: db-reset
db-reset: db-drop db-create
@echo The database has been reset!
dev:
uvicorn main:app --reload
quickstart:
python3 -m venv venv
. venv/bin/activate
pip install -r requirements.txt
make dev
script:
pip install -r scripts/requirements.txt