generated from Hochfrequenz/python_template_repository
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtox.ini
124 lines (112 loc) · 3.28 KB
/
tox.ini
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
[tox]
envlist =
tests
linting
type_check
coverage
json_schemas
spellcheck
skip_missing_interpreters = True
isolated_build = True
[testenv]
commands = python -m pip install --upgrade pip
[testenv:tests]
# the tests environment is called by the Github action that runs the unit tests
usedevelop = True
deps =
-r requirements.txt
.[tests]
commands = python -m pytest --basetemp={envtmpdir} {posargs}
[testenv:linting]
# the linting environment is called by the Github Action that runs the linter
deps =
{[testenv:json_schemas]deps}
-rrequirements.txt
.[linting]
# add your fixtures like e.g. pytest_datafiles here
commands =
pylint src/ahbicht
pylint json_schemas/generate_json_schemas.py
# add single files (ending with .py) or packages here
[testenv:type_check]
usedevelop=True
# the type_check environment is called by the Github Action that runs the static type check (mypy)
# because we type-check the tests it's good to install e.g. pytest in the type_check env
deps =
{[testenv:json_schemas]deps}
{[testenv:tests]deps}
-r requirements.txt
.[type_check]
commands =
mypy --show-error-codes src/ahbicht
mypy --show-error-codes unittests
mypy --show-error-codes json_schemas/generate_json_schemas.py
# add single files (ending with .py) or packages here
[testenv:coverage]
# the coverage environment is called by the Github Action that runs the coverage measurement
usedevelop = True
deps =
{[testenv:tests]deps}
.[coverage]
commands =
coverage run -m pytest --basetemp={envtmpdir} {posargs}
coverage html --omit .tox/*,unittests/*
coverage report --fail-under 95 --omit .tox/*,unittests/*
[testenv:formatting]
deps =
.[formatting]
commands =
black . --check
isort . --check
[testenv:spellcheck]
# the spellcheck environment checks the code for typos
setenv = PYTHONPATH = {toxinidir}/src
deps =
{[testenv:tests]deps}
.[spellcheck]
commands =
codespell --ignore-words=domain-specific-terms.txt --skip "./docs/_static/ahbicht-logo-raw.svg, ./htmlcov, ./docs"
# add single files (ending with .py) or packages here
[testenv:dev]
# the dev environment contains everything you need to start developing on your local machine.
deps =
{[testenv:tests]deps}
{[testenv:linting]deps}
{[testenv:type_check]deps}
{[testenv:coverage]deps}
{[testenv:json_schemas]deps}
{[testenv:formatting]deps}
{[testenv:docs]deps}
nest_asyncio
pre-commit
commands =
python -m pip install --upgrade pip
pip install -r requirements.txt
pre-commit install
[testenv:test_packaging]
skip_install = true
deps =
.[test_packaging]
commands =
python -m build
twine check dist/*
[testenv:docs]
deps =
-r requirements.txt
-r dev_requirements/requirements-docs.txt
commands =
sphinx-build -W -b html -d {envtmpdir}/doctrees docs {envtmpdir}/html
sphinx-build -n -T -W -b doctest -d {envtmpdir}/doctrees docs docs/_build/html
python -m doctest README.rst
[testenv:json_schemas]
usedevelop = True
deps =
-r requirements.txt
.[json_schemas]
commands =
python json_schemas/generate_json_schemas.py
[testenv:update_docs_requirements]
deps =
pip-tools
commands =
pip-compile --upgrade --extra=docs --output-file=dev_requirements/requirements-docs.txt pyproject.toml