-# Copyright (c) 2016-2021 mudpy authors. Permission to use, copy,
+# Copyright (c) 2016-2022 mudpy authors. Permission to use, copy,
# modify, and distribute this software is granted under terms
# provided in the LICENSE file distributed with this software.
[testenv]
description = run the functional selftest with optimized configuration
basepython = python3
-usedevelop = True
-# TODO(fungi) Switch this to "error" once
-# https://github.com/pypa/setuptools/issues/2086 and
-# https://github.com/pypa/setuptools/issues/2466 are fixed in a new release of
-# Setuptools and the vendored copy in Python 3.8 and later updated with it;
-# also that won't work for Python 3.6 due to the older Setuptools there still
-# calling imp instead of importlib so probably not while we still support 3.6
+# TODO(fungi) Switch this to "error" once the following are solved
+#
+# py311... passlib.utils raises DeprecationWarning "'crypt' is deprecated and
+# slated for removal in Python 3.13"
+# py311... mudpy.tests.selftest raises DeprecationWarning "'telnetlib' is
+# deprecated and slated for removal in Python 3.13"
+# multiple callers raise DeprecationWarning "Creating a LegacyVersion has been
+# deprecated and will be removed in the next major release"
+# SetupTools raises
+# setuptools._deprecation_warning.SetuptoolsDeprecationWarning "setup.py
+# install is deprecated. Use build and pip and other standards-based tools."
+# but only the message can be matched because the exception is private
+# SetupTools raises
+# setuptools._deprecation_warning.SetuptoolsDeprecationWarning
+# "setup_requires is deprecated. Supply build dependencies using PEP 517
+# pyproject.toml build-requires." but only the message can be matched because
+# the exception is private
+# SetupTools raises
+# setuptools._deprecation_warning.SetuptoolsDeprecationWarning "easy_install
+# command is deprecated. Use build and pip and other standards-based tools."
+# but only the message can be matched because the exception is private
+# setuptools.config.pyprojecttoml raises
+# setuptools.config.pyprojecttoml._ExperimentalProjectMetadata "Support for
+# `[tool.setuptools]` in `pyproject.toml` is still *beta*." but the parent
+# Warning class has to be used instead
setenv =
- PYTHONWARNINGS=default::DeprecationWarning
- VIRTUALENV_CREATOR=venv
+ PYTHONWARNDFAULTENCODING = 1
+ PYTHONWARNINGS = error, ignore:Creating a LegacyVersion has been deprecated and will be removed in the next major release:DeprecationWarning, ignore:setup.py install is deprecated. Use build and pip and other standards-based tools., ignore:easy_install command is deprecated. Use build and pip and other standards-based tools., ignore:'crypt' is deprecated and slated for removal in Python 3.13:DeprecationWarning:passlib.utils, ignore:'telnetlib' is deprecated and slated for removal in Python 3.13:DeprecationWarning:mudpy.tests.selftest, ignore:Support for `[tool.setuptools]` in `pyproject.toml` is still *beta*.:Warning:setuptools.config.pyprojecttoml
+ PYTHONUTF8 = 1
+ VIRTUALENV_CREATOR = venv
commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
+download = true
+deps = {toxinidir}
[testenv:bandit]
description = check for potential security risks in source code
+skip_install = True
deps = bandit
commands = bandit -r mudpy -x mudpy/tests {posargs}
-usedevelop = False
[testenv:codespell]
description = find common spelling mistakes in code and documentation
+skip_install = True
deps = codespell
commands = codespell {posargs}
-usedevelop = False
[testenv:demo]
description = start an interactive demo with the sample config
[testenv:dist]
description = build release artifacts and check for conformance
-allowlist_externals = rm
+skip_install = True
deps =
- pbr
+ build
twine
- wheel
commands =
- rm -fr dist
- python setup.py bdist_wheel sdist
- twine check --strict dist/*
-usedevelop = False
+ {envpython} -c "import shutil; shutil.rmtree('{toxinidir}/dist', ignore_errors=True)"
+ {envpython} -m build
+ twine check --strict {toxinidir}/dist/*
[testenv:docs]
+# Build an sdist into a temporary location so we'll have AUTHORS and ChangeLog
+# files to include.
description = generate hypertext documentation
-allowlist_externals = rm
deps =
- -r{toxinidir}/requirements.txt
- -r{toxinidir}/doc/requirements.txt
+ {[testenv]deps}
+ build
+ sphinx
commands =
- rm -fr doc/build
- python setup.py sdist
+ {envpython} -c "import shutil; shutil.rmtree('{toxinidir}/doc/build', ignore_errors=True)"
+ {envpython} -m build --outdir={toxinidir}/doc/build/dist --sdist
sphinx-build -W -d doc/build/doctrees -b html doc/source/ doc/build/html
-usedevelop = False
[testenv:flake8]
description = style checks and static analysis of source code
-deps =
- flake8
- flake8-bugbear
+skip_install = True
+deps = flake8-bugbear
commands = flake8 {posargs}
-usedevelop = False
[testenv:selftest_config]
description = run the selftest with the included sample config
commands = mudpy_selftest etc/mudpy.yaml
[testenv:yamllint]
+# Run the selftest before checking YAML files so we'll be sure to also catch at
+# least some which are generated by the application, making sure it creates
+# them with the same style we enforce for those carried in the repository.
description = test data files for correct syntax and formatting
-deps = yamllint
+deps =
+ {[testenv]deps}
+ yamllint
commands =
mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
yamllint --strict {posargs} .
[flake8]
show-source = True
-exclude=.git,.tox,*lib/python*,*egg,build
+exclude = .git, .tox, *lib/python*, *egg, build