-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathMakefile
81 lines (64 loc) · 1.91 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
PY_MODULES=datajob tests
RCFILE=setup.cfg
DOCKER_REGISTRY=mehdio
IMAGE_NAME=spark-py
IMAGE_TAG=3.1-3.7
DOCKER_WORKDIR=/tmp
DOCKER_ARGS=-v $(PWD):$(DOCKER_WORKDIR) -w $(DOCKER_WORKDIR) -u root
#----------- Tests -------------------------------------------------------------
test:
@$(PRE_ACTIVATE) $(MAKE) -j4 --no-print-directory \
test-unit \
test-black \
test-isort \
test-pylint \
test-mypy
test-black: # code formatter
black --check -l 80 $(PY_MODULES)
test-mypy: # typing check
mypy $(PY_MODULES)
test-pylint:
pylint -f parseable \
--rcfile=${RCFILE} \
-j 4 \
$(PY_MODULES)
test-unit:
pytest -vvv -rf -q --cov \
--cov-report term \
$(PY_MODULES) \
$(PYTESTFLAGS)
test-isort:
isort -l80 -m3 -c --tc $(PY_MODULES)
#----------- DEV ---------------------------------------------------------------
black: ## Format all the python code
black -l 80 $(PY_MODULES)
isort: ## Sort imports in the python module
isort -l80 -m3 --tc $(PY_MODULES)
#------------ PACKAGING -------------------------------------------------------
package:
./docker/script/package_zip.sh
#------------ RUN/DEBUG -------------------------------------------------------
run:
spark-submit \
--jars jars/spark-excel_2.11-0.9.9.jar \
--py-files datajob.zip \
datajob/cli.py \
--job-name demo_job
#------------ DOCKER -----------------------------------------------------------
build-docker: ### Build the docker image
docker build .\
-t ${DOCKER_REGISTRY}/${IMAGE_NAME}:${IMAGE_TAG} \
-f docker/dev.Dockerfile
test-docker:
docker run --rm \
${DOCKER_ARGS} \
${DOCKER_REGISTRY}/${IMAGE_NAME}:${IMAGE_TAG} \
make test-unit
run-docker:
docker run -it \
${DOCKER_ARGS} \
${DOCKER_REGISTRY}/${IMAGE_NAME}:${IMAGE_TAG} \
/bin/bash -c "make package; make run"
#------------ MISC -----------------------------------------------------------
intall-py-deps:
poetry config virtualenvs.create false && poetry install