generated from canonical/platform-engineering-charm-template
-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathtox.ini
115 lines (102 loc) · 3.04 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
# Copyright 2025 Canonical Ltd.
# See LICENSE file for licensing details.
[tox]
skipsdist=True
skip_missing_interpreters = True
envlist = lint-mock, lint, unit, static, coverage-report, coverage-xml
[vars]
lib_path = {toxinidir}/charms/worker/k8s/lib
src_path = {toxinidir}/charms/worker/k8s/src {[vars]lib_path}/charms/k8s {toxinidir}/charms/worker/k8s/scripts
tst_path = {toxinidir}/tests/ {toxinidir}/charms/worker/k8s/tests/
all_path = {[vars]tst_path} {[vars]src_path}
[testenv]
setenv =
PYTHONBREAKPOINT=ipdb.set_trace
PY_COLORS=1
passenv =
PYTHONPATH
CHARM_BUILD_DIR
MODEL_SETTINGS
[testenv:format]
allowlist_externals = tox
description = Apply coding style standards to code
deps =
ruff
commands =
ruff format {[vars]all_path}
ruff check --fix {[vars]all_path}
[testenv:lint-mock]
description = Provide mock lint commands to use ruff instead
commands =
python -c "'pydocstyle'"
python -c "'codespell'"
python -c "'flake8'"
python -c "'black'"
python -c "'isort'"
python -c "'pylint'"
python -c "'flake8-docstrings'"
python -c "'flake8-docstrings-complete'"
python -c "'flake8-builtins'"
python -c "'flake8-test-docs'"
python -c "'pep8-naming'"
[testenv:lint]
description = Check code against coding style standards
setenv =
PYTHONPATH = {envdir}{:}{[vars]lib_path}
deps =
mypy
ruff
pydantic[mypy]
types-PyYAML
commands =
ruff format --check {[vars]all_path}
ruff check {[vars]all_path}
mypy {[vars]all_path}
[testenv:unit]
allowlist_externals = tox
deps =
-r test_requirements.txt
commands =
tox -c {toxinidir}/charms/worker/k8s -e unit -- {posargs}
[testenv:coverage-report]
allowlist_externals = tox
commands =
tox -c {toxinidir}/charms/worker/k8s -e coverage-report
[testenv:coverage-xml]
allowlist_externals = tox
commands =
tox -c {toxinidir}/charms/worker/k8s -e coverage-xml
[testenv:static]
description = Run static analysis tests
deps =
bandit[toml]
commands =
bandit -c {toxinidir}/pyproject.toml -r {[vars]all_path}
[testenv:{integration,integration-k8s,integration-etcd,integration-ceph,integration-upgrade}]
description = Run integration tests
deps = -r test_requirements.txt
commands =
pytest -v --tb native \
-s {toxinidir}/tests/integration \
--log-cli-level INFO \
--log-format "%(asctime)s %(levelname)s %(message)s" \
--log-date-format "%Y-%m-%d %H:%M:%S" \
--exitfirst \
--crash-dump=on-failure \
--crash-dump-args='-j snap.k8s.* --as-root' \
{posargs}
[testenv:deploy-terraform]
description = Deploy a k8s-operator cluster with terraform
deps = {[testenv:integration]deps}
commands = python3 {toxinidir}/tests/integration/terraform_setup.py {posargs}
passenv = TF_VAR_*
[testenv:src-docs]
allowlist_externals=sh
setenv =
PYTHONPATH = {toxinidir}:{toxinidir}/lib:{[vars]src_path}
description = Generate documentation for src
deps =
lazydocs
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