-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtox.ini
132 lines (122 loc) · 3.63 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
125
126
127
128
129
130
131
132
# Copyright 2025 Canonical Ltd.
# See LICENSE file for licensing details.
[tox]
skipsdist=True
envlist = lint, unit, static, coverage-report
skip_missing_interpreters = True
[vars]
src_path = {toxinidir}/src/paas_charm/
legacy_src_path ={toxinidir}/src/paas_app_charmer/
example_path = {toxinidir}/examples/
tst_path = {toxinidir}/tests/
all_path = {[vars]src_path} {[vars]example_path} {[vars]tst_path} {[vars]legacy_src_path}
[testenv]
setenv =
PYTHONPATH={toxinidir}:{toxinidir}/examples/flask/src:{toxinidir}/examples/flask/lib:{toxinidir}/src
PYTHONBREAKPOINT=ipdb.set_trace
PY_COLORS=1
passenv =
PYTHONPATH
CHARM_BUILD_DIR
MODEL_SETTINGS
[testenv:fmt]
description = Apply coding style standards to code
deps =
black
isort
commands =
isort {[vars]all_path}
black {[vars]all_path} --target-version=py310
[testenv:lint]
description = Check code against coding style standards
deps =
black
codespell
flake8-builtins
flake8-copyright
flake8-docstrings-complete>=1.0.4
flake8-docstrings>=1.6.0
flake8-test-docs
flake8
isort
types-requests
types-PyYAML
mypy
pep8-naming
pydocstyle
pylint
pyproject-flake8
pytest_operator
types-requests
types-PyYAML
-r{toxinidir}/requirements.txt
-r{toxinidir}/tests/integration/requirements.txt
commands =
codespell {toxinidir} \
--skip {toxinidir}/.git \
--skip {toxinidir}/.tox \
--skip {toxinidir}/build \
--skip {toxinidir}/examples/*/charm/lib/charms/data_platform_libs \
--skip {toxinidir}/lib \
--skip {toxinidir}/venv \
--skip {toxinidir}/.mypy_cache \
--skip {toxinidir}/examples/django/charm/lib \
--skip {toxinidir}/examples/fastapi/charm/lib \
--skip {toxinidir}/examples/go/charm/lib \
--skip {toxinidir}/examples/flask/lib \
--skip {toxinidir}/tests/integration/.mypy_cache
# pflake8 wrapper supports config from pyproject.toml
pflake8 {[vars]src_path} {[vars]legacy_src_path}
isort --check-only --diff {[vars]all_path}
black --target-version=py310 --check --diff {[vars]all_path}
mypy {[vars]src_path} {[vars]legacy_src_path}
pydocstyle {[vars]src_path} {[vars]legacy_src_path}
pylint {[vars]src_path} {[vars]legacy_src_path} --min-similarity-lines=10
[testenv:static]
description = Run static analysis tests
deps =
bandit[toml]
-r{toxinidir}/requirements.txt
commands =
bandit -c {toxinidir}/pyproject.toml -r {[vars]src_path} {[vars]tst_path}
[testenv:unit]
description = Run unit tests
deps =
cosl
pytest
coverage[toml]
-r{toxinidir}/requirements.txt
commands =
coverage run --source={[vars]src_path},{[vars]legacy_src_path} \
-m pytest --ignore={[vars]tst_path}integration -v --tb native -s {posargs}
coverage report
[testenv:coverage-report]
description = Create test coverage report
deps =
pytest
coverage[toml]
-r{toxinidir}/requirements.txt
commands =
coverage report
[testenv:integration]
description = Run integration tests
deps =
cosl
boto3
juju==3.5.2.1
git+https://github.com/canonical/saml-test-idp.git
-r{toxinidir}/requirements.txt
-r{toxinidir}/tests/integration/requirements.txt
commands =
pytest -v --tb native --ignore={[vars]tst_path}unit --log-cli-level=INFO -s {posargs}
[testenv:src-docs]
allowlist_externals=sh
setenv =
PYTHONPATH = {toxinidir}:{toxinidir}/lib:{[vars]src_path}
description = Generate documentation for src
deps =
lazydocs
-r{toxinidir}/requirements.txt
commands =
; can't run lazydocs directly due to needing to run it on src/* which produces an invocation error in tox
sh generate-src-docs.sh