generated from Hochfrequenz/python_template_repository
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tox.ini
105 lines (95 loc) · 3.12 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
[tox]
envlist =
tests
linting
coverage
type_check
skip_missing_interpreters = True
skipsdist = 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
deps =
-r requirements.txt
.[tests]
setenv = PYTHONPATH = {toxinidir}/src
commands = python -m pytest --basetemp={envtmpdir} {posargs} --ignore integrationtests
[testenv:integrationtests]
passenv = AUTH0_TEST_CLIENT_ID,AUTH0_TEST_CLIENT_SECRET
# the integrationtests environment is called by the Github action that runs the integration tests
# other than the (unit) tests, this requires a docker container with transformer.bee to be running
deps =
-r requirements.txt
.[tests]
setenv = PYTHONPATH = {toxinidir}/src
commands = python -m pytest --basetemp={envtmpdir} {posargs} --ignore unittests
[testenv:linting]
# the linting environment is called by the Github Action that runs the linter
deps =
{[testenv:tests]deps}
.[linting]
# add your fixtures like e.g. pytest_datafiles here
setenv = PYTHONPATH = {toxinidir}/src
commands =
pylint transformerbeeclient
pylint unittests --rcfile=unittests/.pylintrc
pylint integrationtests --rcfile=integrationtests/.pylintrc
# add single files (ending with .py) or packages here
[testenv:type_check]
# the type_check environment checks the type hints using mypy
setenv = PYTHONPATH = {toxinidir}/src
deps =
{[testenv:tests]deps}
.[type_check]
commands =
mypy --show-error-codes src/transformerbeeclient
mypy --show-error-codes unittests
mypy --show-error-codes integrationtests
# add single files (ending with .py) or packages here
[testenv:spell_check]
# the spellcheck environment checks the code for typos
setenv = PYTHONPATH = {toxinidir}/src
deps =
-r requirements.txt
.[spellcheck]
commands =
codespell --ignore-words=domain-specific-terms.txt src
codespell --ignore-words=domain-specific-terms.txt README.md
# add single files (ending with .py) or packages here
[testenv:coverage]
passenv = AUTH0_TEST_CLIENT_ID,AUTH0_TEST_CLIENT_SECRET
# the coverage environment is called by the Github Action that runs the coverage measurement
changedir = integrationtests
deps =
{[testenv:tests]deps}
.[coverage]
setenv = PYTHONPATH = {toxinidir}/src
# note, that we collect the coverage from the integration test path here!
commands =
coverage run -m pytest --basetemp={envtmpdir} {posargs}
coverage html --omit .tox/*,integrationtests/*
coverage report --fail-under 84 --omit .tox/*,integrationtests/*
[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:spell_check]deps}
.[formatting]
pip-tools
pre-commit
commands =
python -m pip install --upgrade pip
pip-compile pyproject.toml
pip install -r requirements.txt
pre-commit install
[testenv:test_packaging]
skip_install = true
deps =
.[packaging]
commands =
python -m build
twine check dist/*