-
Notifications
You must be signed in to change notification settings - Fork 4
/
Makefile
103 lines (72 loc) · 3.14 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
# Defines help target logic
# Add help text after each target name starting with '\#\#'
# Inspired by <https://gist.github.com/prwhite/8168133>
DOCKER_RUN = docker-compose run --rm -e STANDALONE=true --no-deps -u root -w /code api
DOCKER_RUN_DB = docker-compose run --rm -u root -w /code api
DOCKER_COMPOSE_TESTS = docker-compose -p asheslive_tests -f docker-compose.yml -f docker-compose.test.yml
##=== Welcome to Ashes.live! ===
help: ## Show this help.
@$(DOCKER_RUN) make _help
_help:
@fgrep -h "##" $(MAKEFILE_LIST) | fgrep -v fgrep | sed -e 's/\\$$//' | sed -E -e 's/:\s+\|?\s*[a-z_][ a-z_-]+?[a-z](\s+)##/:\1/' | sed -e 's/##//'
##
##=== Local development ===
up: ## Run development server
@docker-compose up
test: ## Execute test suite; or specify target: `make test ARGS='api/tests/cards'`
@$(DOCKER_COMPOSE_TESTS) run --rm -w /code -u root api \
pytest --cov=api --cov-config=.coveragerc --cov-report=term:skip-covered --cov-report=html $(ARGS)
test-rm: ## Cleans up test coverage artifacts; useful if coverage is innacurate
@$(DOCKER_COMPOSE_TESTS) run --rm -w /code -u root api coverage erase
@echo 'Test coverage cleaned up!'
# This ensures that even if they pass in an empty value, we default to "head"
ifndef REV
override REV = head
endif
migrate: clean-api ## Run database migrations; or specify a revision: `make migrate REV='head'`
@$(DOCKER_RUN_DB) alembic upgrade $(REV)
# This ensures that even if they pass in an empty value, we default to parsing the "api" folder
ifndef FILEPATH
override FILEPATH = api
endif
format: ## Format via isort and black; or specify a file: `make format FILEPATH='api/main.py'`
@$(DOCKER_RUN) make _format FILEPATH="$(FILEPATH)"
_format:
@black "$(FILEPATH)"
@isort "$(FILEPATH)"
##
##=== Access internals ===
db: ## Run standalone postgres server; accessible at localhost:5432
@docker-compose run --service-ports --rm postgres
shell: ## Open a bash shell to API (warning: root user!)
@$(DOCKER_RUN) bash
shell-db: ## Open a bash shell to API with the database running
@$(DOCKER_RUN_DB) bash
##
##=== Docker maintenance ===
build: ## Rebuild the main app container
@docker-compose build --no-cache api
clean-api:
@docker-compose down --remove-orphans
clean-tests:
@$(DOCKER_COMPOSE_TESTS) down --remove-orphans
clean: clean-api clean-tests ## Clean up Docker containers, images, etc.
@echo 'All clean!'
##
stack: ## Rebuild the entire stack
@docker-compose pull
@docker-compose build
reset: ## Completely remove all images, containers, and volumes (DANGER!)
@docker-compose down --rmi all --remove-orphans --volumes
@echo
@echo 'You should now run `make stack`, `make db`, then populate your database!'
##
##=== First run ===
_pre-example-data:
@$(DOCKER_RUN_DB) alembic upgrade 6b6df338dfc3
_populate-example-data: clean-api
@docker-compose run -v `pwd`/docker/scripts:/scripts -u postgres --rm postgres /scripts/example_data.sh
_post-example-data:
@$(DOCKER_RUN_DB) alembic upgrade head
# Pipe causes these to be executed in strict order
data: | _pre-example-data _populate-example-data _post-example-data ## Populate example data (requires empty database!)