-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathMakefile
95 lines (70 loc) · 2.64 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
.PHONY: clean clean-test clean-pyc clean-build docs help test test-cov
.DEFAULT_GOAL := help
clean: ## remove all build, test, coverage and Python artifacts
@echo -----------------------------------------------------------------
@echo CLEANING UP ...
make clean-build clean-pyc clean-test
@echo ALL CLEAN.
@echo -----------------------------------------------------------------
clean-build: ## remove build artifacts
@echo cleaning build artifacts ...
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
clean-pyc: ## remove Python file artifacts
@echo cleaning pyc 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
@echo cleaning test artifacts ...
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
rm -fr .hypothesis
rm -fr .mypy_cache
test: ## run tests (and coverage if configured in setup.cfg) with the default Python
@echo -----------------------------------------------------------------
@echo RUNNING TESTS...
poetry run pytest -v --cov=sparkdantic
@echo ✅ Tests have passed! Nice work!
@echo -----------------------------------------------------------------
coverage: ## check code coverage quickly with the default Python
@echo producing coverage report at COVERAGE.txt...
coverage report > COVERAGE.txt
test-ci:
poetry run pytest --cov=sparkdantic --cov-report=json
dist: clean ## builds source and wheel package
poetry build
ls -l dist
install: clean ## install the package to the active Python's site-packages via pip
poetry install
install-e: clean ## install via pip in editable mode this see https://pip.pypa.io/en/stable/reference/pip_install/#editable-installs
pip install -e .
test-cov: test ## run tests locally and output coverage file
poetry run coverage report > COVERAGE.txt
commit-cov:
git add COVERAGE.txt --force
install-docs:
poetry install --only docs
install-tests:
poetry install --only test
install-all:
poetry install --with dev,test,docs -E pyspark
install-dev-local: ## install all the stuff you need to develop locally
pip install --upgrade pip
pip install wheel
pip install -e .
poetry install --with dev,test,docs -E pyspark
pre-commit install
publish: dist ## publish the package to PyPI
poetry publish
run-infra:
docker-compose -f docker/dev/docker-compose.yaml up --remove-orphans -d
stop-infra:
docker-compose -f docker/dev/docker-compose.yaml down
docs: ## generate Sphinx HTML documentation, including API docs
poetry run mkdocs build