# py311... Cython.Compiler.Main raises FutureWarning "Cython directive
# 'language_level' not set, using 2 for now (Py2). This will change in a
# later release!" but this can't be matched by message because it has a comma
-# py311... pip._vendor.pyparsing.core and pkg_resources._vendor.pyparsing raise
-# DeprecationWarning "module 'sre_constants' is deprecated" until a new
-# release containing https://github.com/pyparsing/pyparsing/commit/3c03942 is
-# vendored into pip and pkg_resources
+# py311... pip._internal.index.collector and Cython.Tempita raise
+# DeprecationWarning "'cgi' is deprecated and slated for removal in Python
+# 3.13"
+# 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"
# py310... distutils.command.install raises DeprecationWarning "The
# distutils.sysconfig module is deprecated, use sysconfig instead" but this
# can't be matched by message because it contains a comma
# flake8... flake8.plugins.manager raises DeprecationWarning "SelectableGroups
# dict interface is deprecated. Use select."
+# yamllint... setuptools.command.build_py raises
+# setuptools._deprecation_warning.SetuptoolsDeprecationWarning "Installing
+# 'yamllint.conf' as data is deprecated, please list it in `packages`. [...]"
+# but the message can't be matched because it contains a comma and spans
+# multiple lines while the custom Warning subclass can't be matched
+# specifically leading to a blanket ignore for all Warning types in package
+# builds
# multiple callers raise DeprecationWarning "The distutils package is
# deprecated and slated for removal in Python 3.12. Use setuptools or check
# PEP 632 for potential alternatives"
# 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
# pip._vendor.certifi.core and pip._vendor.pep517.in_process raise
# DeprecationWarning "path is deprecated. Use files() instead. Refer to
# https://importlib-resources.readthedocs.io/en/latest/using.html#migrating-from-legacy
# for migration advice." but this can't be matched by message because it
# contains a colon
setenv =
- PYTHONWARNINGS = error, ignore::FutureWarning:Cython.Compiler.Main, ignore::DeprecationWarning:distutils.command.install, ignore:The distutils package is deprecated and slated for removal in Python 3.12. Use setuptools or check PEP 632 for potential alternatives:DeprecationWarning, ignore:Creating a LegacyVersion has been deprecated and will be removed in the next major release:DeprecationWarning, ignore:SelectableGroups dict interface is deprecated. Use select.:DeprecationWarning:flake8.plugins.manager, 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::DeprecationWarning:pip._vendor.certifi.core, ignore::DeprecationWarning:pip._vendor.pep517.in_process, ignore:module 'sre_constants' is deprecated:DeprecationWarning:pip._vendor.pyparsing.core, ignore:module 'sre_constants' is deprecated:DeprecationWarning:pkg_resources._vendor.pyparsing
+ PYTHONWARNDFAULTENCODING = 1
+ PYTHONWARNINGS = error, ignore::FutureWarning:Cython.Compiler.Main, ignore::DeprecationWarning:distutils.command.install, ignore:The distutils package is deprecated and slated for removal in Python 3.12. Use setuptools or check PEP 632 for potential alternatives:DeprecationWarning, ignore:Creating a LegacyVersion has been deprecated and will be removed in the next major release:DeprecationWarning, ignore:SelectableGroups dict interface is deprecated. Use select.:DeprecationWarning:flake8.plugins.manager, 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::DeprecationWarning:pip._vendor.certifi.core, ignore::DeprecationWarning:pip._vendor.pep517.in_process, ignore:'cgi' is deprecated and slated for removal in Python 3.13:DeprecationWarning:pip._internal.index.collector, ignore:'cgi' is deprecated and slated for removal in Python 3.13:DeprecationWarning:Cython.Tempita, 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::Warning:setuptools.command.build_py, 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}
[testenv:codespell]
description = find common spelling mistakes in code and documentation
+skip_install = True
deps = codespell
commands = codespell {posargs}
[testenv:dist]
description = build release artifacts and check for conformance
-allowlist_externals = rm
+skip_install = True
deps =
build
twine
commands =
- rm -fr {toxinidir}/dist
- python -m build
+ {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 =
- {toxinidir}
+ {[testenv]deps}
build
sphinx
commands =
- rm -fr {toxinidir}/doc/build
- python -m build --outdir={toxinidir}/doc/build/dist --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
[testenv:flake8]
description = style checks and static analysis of source code
-deps =
- flake8
- flake8-bugbear
+skip_install = True
+deps = flake8-bugbear
commands = flake8 {posargs}
[testenv:selftest_config]
# them with the same style we enforce for those carried in the repository.
description = test data files for correct syntax and formatting
deps =
- {toxinidir}
+ {[testenv]deps}
yamllint
commands =
mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml