-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathMakefile
120 lines (98 loc) · 2.93 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
SOURCES=$(wildcard *.py) craft_parts tests
.PHONY: help
help: ## Show this help.
@printf "%-30s %s\n" "Target" "Description"
@printf "%-30s %s\n" "------" "-----------"
@fgrep " ## " $(MAKEFILE_LIST) | fgrep -v grep | awk -F ': .*## ' '{$$1 = sprintf("%-30s", $$1)} 1'
.PHONY: autoformat
autoformat: ## Run automatic code formatters.
autoflake --remove-all-unused-imports --ignore-init-module-imports -ri $(SOURCES)
ruff check --fix $(SOURCES)
black $(SOURCES)
.PHONY: clean
clean: ## Clean artifacts from building, testing, etc.
rm -rf build/
rm -rf dist/
rm -rf .eggs/
find . -name '*.egg-info' -exec rm -rf {} +
find . -name '*.egg' -exec rm -f {} +
rm -rf docs/_build/
rm -f docs/craft_parts.*
rm -f docs/modules.rst
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -rf {} +
rm -rf .tox/
rm -f .coverage
rm -rf htmlcov/
rm -rf .pytest_cache
.PHONY: coverage
coverage: ## Run pytest with coverage report.
coverage run --source craft_parts -m pytest tests/unit
coverage report -m
coverage xml
.PHONY: preparedocs
preparedocs: ## move file from the sphinx-starter-pack to docs folder
cp docs/sphinx-resources/.sphinx/_static/* docs/_static
mkdir -p docs/_templates
cp -R docs/sphinx-resources/.sphinx/_templates/* docs/_templates
cp docs/sphinx-resources/.sphinx/spellingcheck.yaml docs/spellingcheck.yaml
.PHONY: installdocs
installdocs: preparedocs ## install documentation dependencies.
$(MAKE) -C docs install
.PHONY: docs
docs: ## Generate documentation.
rm -f docs/craft_parts.rst
rm -f docs/modules.rst
pip install -r docs/requirements.txt
$(MAKE) -C docs clean
$(MAKE) -C docs html
.PHONY: dist
dist: clean ## Build python package.
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
.PHONY: install
install: clean ## Install python package.
python setup.py install
.PHONY: lint
lint: test-black test-codespell test-ruff test-mypy test-pydocstyle test-pyright ## Run all linting tests
.PHONY: release
release: dist ## Release with twine.
twine upload dist/*
.PHONY: test-black
test-black:
black --check --diff $(SOURCES)
.PHONY: test-codespell
test-codespell:
codespell $(SOURCES) --ignore-words-list crate
.PHONY: test-flake8
test-flake8:
echo "\033[0;31mWARNING\033[0m: Did you mean to run \`make ruff\`?"
flake8 $(SOURCES)
.PHONY: test-ruff
test-ruff:
ruff check $(SOURCES)
.PHONY: test-integrations
test-integrations: ## Run integration tests.
pytest tests/integration
.PHONY: test-mypy
test-mypy:
mypy $(SOURCES)
.PHONY: test-pydocstyle
test-pydocstyle:
pydocstyle craft_parts
.PHONY: test-pyright
test-pyright:
pyright $(SOURCES)
.PHONY: test-units
test-units: ## Run unit tests.
pytest tests/unit
.PHONY: test-docs
test-docs: installdocs ## Run docs tests.
$(MAKE) -C docs linkcheck
$(MAKE) -C docs woke
$(MAKE) -C docs spelling
.PHONY: tests
tests: lint test-units test-integrations ## Run all tests.