-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
145 lines (123 loc) · 4.69 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
PROJECT_NAME = data-pipeline-mini-example
ifeq (,$(shell which conda))
HAS_CONDA=False
else
HAS_CONDA=True
endif
# Need to specify bash in order for conda activate to work.
SHELL=/bin/bash
# Note that the extra activate is needed to ensure that the activate floats env to the front of PATH
CONDA_ACTIVATE=source $$(conda info --base)/etc/profile.d/conda.sh ; conda activate ; conda activate
# https://stackoverflow.com/questions/53382383/makefile-cant-use-conda-activate
## Set up python interpreter environment
create_environment: ## create conda environment for analysis
ifeq (True,$(HAS_CONDA))
@echo ">>> Detected conda, creating conda environment."
mamba env create --force --name $(PROJECT_NAME) -f environment.yml
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; pip install --editable .)
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; cd dpme_dbt && dbt deps && cd ..)
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; cd dpme_dbt && dbt parse --profiles-dir config)
@echo ">>> New conda env created. Activate with:\nsource activate $(PROJECT_NAME)"
endif
## Set up python interpreter environment OSX (apple silicon in case of missing packages)
create_environment_osx: ## create conda environment for analysis
ifeq (True,$(HAS_CONDA))
@echo ">>> Detected conda, creating conda environment."
# using mamba to speed things up and get better error messages
# conda env create --force --name $(PROJECT_NAME) -f environment.yml
CONDA_SUBDIR=osx-64 mamba env create --force --name $(PROJECT_NAME) -f environment.yml
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; pip install --editable .)
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; cd dpme_dbt && dbt deps && cd ..)
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; cd dpme_dbt && dbt parse --profiles-dir config)
@echo ">>> New conda env created. Activate with:\nsource activate $(PROJECT_NAME)"
endif
delete_environment: ## delete conda environment for analysis
conda remove --name $(PROJECT_NAME) --all -y
## start notebook (jupyter lab)
notebook:
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; jupyter lab)
## start dagster dev webserver
dagster-webserver:
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; dagster dev)
## autoformat the codebase
.PHONY: fmt
fmt:
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; black dpme dpme_tests && isort dpme dpme_tests && yamllint -c yamllint_config.yaml .)
## lint the codebase
.PHONY: lint
lint:
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; ruff dpme dpme_tests && mypy dpme dpme_tests)
## test the codebase
.PHONY: test
test:
($(CONDA_ACTIVATE) "${PROJECT_NAME}" ; pytest --ignore=dpme_dbt/dbt_packages .)
## start database container (in detached mode)
.PHONY: start
start:
@docker compose --profile warehouse up -d
.PHONY: delete-dangling
delete-dangling:
docker rmi $(docker images -f "dangling=true" -q)
cleanup:
rm -r z_tmp/postgres
#################################################################################
# PROJECT RULES #
#################################################################################
#################################################################################
# Self Documenting Commands #
#################################################################################
.DEFAULT_GOAL := help
# Inspired by <http://marmelab.com/blog/2016/02/29/auto-documented-makefile.html>
# sed script explained:
# /^##/:
# * save line in hold space
# * purge line
# * Loop:
# * append newline + line to hold space
# * go to next line
# * if line starts with doc comment, strip comment character off and loop
# * remove target prerequisites
# * append hold space (+ newline) to line
# * replace newline plus comments by `---`
# * print line
# Separate expressions are necessary because labels cannot be delimited by
# semicolon; see <http://stackoverflow.com/a/11799865/1968>
.PHONY: help
help:
@echo "$$(tput bold)Available rules:$$(tput sgr0)"
@echo
@sed -n -e "/^## / { \
h; \
s/.*//; \
:doc" \
-e "H; \
n; \
s/^## //; \
t doc" \
-e "s/:.*//; \
G; \
s/\\n## /---/; \
s/\\n/ /g; \
p; \
}" ${MAKEFILE_LIST} \
| LC_ALL='C' sort --ignore-case \
| awk -F '---' \
-v ncol=$$(tput cols) \
-v indent=19 \
-v col_on="$$(tput setaf 6)" \
-v col_off="$$(tput sgr0)" \
'{ \
printf "%s%*s%s ", col_on, -indent, $$1, col_off; \
n = split($$2, words, " "); \
line_length = ncol - indent; \
for (i = 1; i <= n; i++) { \
line_length -= length(words[i]) + 1; \
if (line_length <= 0) { \
line_length = ncol - indent - length(words[i]) - 1; \
printf "\n%*s ", -indent, " "; \
} \
printf "%s ", words[i]; \
} \
printf "\n"; \
}' \
| more $(shell test $(shell uname) = Darwin && echo '--no-init --raw-control-chars')