1 # Copyright (c) 2016-2021 mudpy authors. Permission to use, copy,
2 # modify, and distribute this software is granted under terms
3 # provided in the LICENSE file distributed with this software.
7 envlist = bandit, codespell, dist, docs, flake8, yamllint, selftest_config, py3
9 ignore_basepython_conflict = True
12 description = run the functional selftest with optimized configuration
15 # TODO(fungi) Switch this to "error" once the following are solved
17 # py310... importlib._bootstrap raises ImportWarning:
18 # _SixMetaPathImporter.find_spec() not found; falling back to find_module()
19 # all... pip._vendor.packaging.version raises DeprecationWarning: Creating a
20 # LegacyVersion has been deprecated and will be removed in the next major
22 # yamllint... pip._vendor.packaging.specifiers raises DeprecationWarning:
23 # Creating a LegacyVersion has been deprecated and will be removed in the
25 # py310... pip._vendor.packaging.tags and setuptools both raise
26 # DeprecationWarning: The distutils package is deprecated and slated for
27 # removal in Python 3.12. Use setuptools or check PEP 632 for potential
30 PYTHONWARNINGS = error, ignore:::importlib._bootstrap, ignore:::pip._vendor.packaging.version, ignore:::pip._vendor.packaging.specifiers, ignore:::pip._vendor.packaging.tags, ignore:::setuptools
31 VIRTUALENV_CREATOR = venv
32 commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
35 description = check for potential security risks in source code
37 commands = bandit -r mudpy -x mudpy/tests {posargs}
41 description = find common spelling mistakes in code and documentation
43 commands = codespell {posargs}
47 description = start an interactive demo with the sample config
48 commands = mudpy {posargs}
51 description = build release artifacts and check for conformance
52 allowlist_externals = rm
58 rm -fr {toxinidir}/dist
59 python setup.py bdist_wheel sdist
60 twine check --strict {toxinidir}/dist/*
64 description = generate hypertext documentation
65 allowlist_externals = rm
67 -r{toxinidir}/requirements.txt
68 -r{toxinidir}/doc/requirements.txt
72 sphinx-build -W -d doc/build/doctrees -b html doc/source/ doc/build/html
76 description = style checks and static analysis of source code
80 commands = flake8 {posargs}
83 [testenv:selftest_config]
84 description = run the selftest with the included sample config
85 commands = mudpy_selftest etc/mudpy.yaml
88 description = test data files for correct syntax and formatting
91 mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
92 yamllint --strict {posargs} .
96 exclude = .git, .tox, *lib/python*, *egg, build