forked from siklosid/dagger
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Makefile
145 lines (113 loc) · 4.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
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
.PHONY: clean clean-test clean-pyc clean-build docs help
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
try:
from urllib import pathname2url
except:
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
define PRINT_HELP_PYSCRIPT
import re, sys
for line in sys.stdin:
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
if match:
target, help = match.groups()
print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
BROWSER := python -c "$$BROWSER_PYSCRIPT"
include .common.env
export
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-venv clean-build clean-pyc clean-test ## remove all build, test, coverage and Python artifacts
clean-venv: ## remove virtualenv
$(shell if command -v deactivate ; then deactivate ; fi)
rm -fr venv
rm -fr venv_ui
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -rf {} +
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
clean-test: ## remove test and coverage artifacts
rm -fr .tox/
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
lint: ## check style with flake8
flake8 dagger tests
test: ## run tests quickly with the default Python
AIRFLOW_HOME=$(shell pwd)/tests/fixtures/config_finder/root/ \
ENV=local \
pytest -s
coverage: ## check code coverage quickly with the default Python
coverage run --source dagger setup.py test
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/dagger.rst
rm -f docs/modules.rst
sphinx-apidoc -o docs/ dagger
$(MAKE) -C docs clean
$(MAKE) -C docs html
$(BROWSER) docs/_build/html/index.html
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
release: dist ## package and upload a release
twine upload dist/*
dist: clean ## builds source and wheel package
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
install: clean ## install the package to the active Python's site-packages
python setup.py install
install-dev: clean ## install the package to the active Python's site-packages
virtualenv -p python3.9 venv; \
source venv/bin/activate; \
python -m pip install --upgrade pip; \
python setup.py install; \
pip install -e . ; \
SYSTEM_VERSION_COMPAT=0 CFLAGS='-std=c++20' pip install -r reqs/dev.txt -r reqs/test.txt
install-test: clean ## install the package to the active Python's site-packages
virtualenv -p python3.9 venv; \
source venv/bin/activate; \
python -m pip install --upgrade pip; \
pip install -r reqs/test.txt -r reqs/base.txt
install-ui: clean ## install the package to the active Python's site-packages
virtualenv -p python3 venv_ui; \
source venv_ui/bin/activate; \
python -m pip install --upgrade pip; \
python setup.py install; \
pip install -r reqs/ui.txt
build-airflow: ## Build airflow image
build-airflow: PROJ_NAME="airflow"
build-airflow:
docker build --build-arg AIRFLOW_VERSION=${AIRFLOW_VERSION} -t ${DOCKER_REGISTRY}/${PROJ_NAME}:${AIRFLOW_VERSION} ./dockers/airflow
build-dagger_ui: ## Build dagger_ui image
build-dagger_ui: PROJ_NAME="dagger_ui"
build-dagger_ui:
docker build -t ${DOCKER_REGISTRY}/${PROJ_NAME}:"v0.1" ./dockers/dagger_ui
test-airflow: ## Run airflow image locally | args: services
test-airflow: export ARGS=$(shell if [ "${logs}" != "true" ]; then echo "-d"; fi)
test-airflow: build-airflow
AIRFLOW_DAGS_DIR=$(shell pwd)/tests/fixtures/config_finder/root/dags \
DAGGER_DIR=$(shell pwd)/dagger \
DOCKERS_DIR=$(shell pwd)/dockers \
docker-compose -f dockers/docker-compose.local.yml up ${ARGS} ${services}
stop-airflow: ## Stopping airflow
stop-airflow:
docker-compose -f dockers/docker-compose.local.yml down
airflow-scheduler: ## Log in to scheduler
airflow-scheduler:
docker exec -it dockers_scheduler_1 sh -c 'cd ~/dags && bash'