Drop deprecation filters for pip and yamllint
[mudpy.git] / tox.ini
diff --git a/tox.ini b/tox.ini
index 505edf6..33c4fb9 100644 (file)
--- a/tox.ini
+++ b/tox.ini
@@ -1,4 +1,4 @@
-# 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.
 
@@ -11,37 +11,51 @@ ignore_basepython_conflict = True
 [testenv]
 description = run the functional selftest with optimized configuration
 basepython = python3
-usedevelop = True
 # TODO(fungi) Switch this to "error" once the following are solved
 #
-# py310... distutils.command.install raises DeprecationWarning: The
-#   distutils.sysconfig module is deprecated, use sysconfig instead
-# py310... importlib._bootstrap raises ImportWarning:
-#   _SixMetaPathImporter.find_spec() not found; falling back to find_module()
-# yamllint... pip._vendor.packaging.specifiers raises DeprecationWarning:
-#   Creating a LegacyVersion has been deprecated and will be removed in the
-#   next major release
-# py310... pip._vendor.packaging.tags raises DeprecationWarning: The distutils
-#   package is deprecated and slated for removal in Python 3.12. Use setuptools
-#   or check PEP 632 for potential alternatives
-# py310... pip._vendor.urllib3.connection and pip._vendor.urllib3.util.ssl_
-#   both raise DeprecationWarning: ssl module: PROTOCOL_TLS is deprecated
+# 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 = error, ignore:::distutils.command.install, ignore:::importlib._bootstrap, ignore:::pip._vendor.packaging.specifiers, ignore:::pip._vendor.packaging.tags, ignore:::pip._vendor.urllib3.connection, ignore:::pip._vendor.urllib3.util.ssl_
+    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
@@ -49,44 +63,46 @@ commands = mudpy {posargs}
 
 [testenv:dist]
 description = build release artifacts and check for conformance
-allowlist_externals = rm
+skip_install = True
 deps =
-    pbr
+    build
     twine
-    wheel
 commands =
-    rm -fr {toxinidir}/dist
-    python setup.py bdist_wheel sdist
+    {envpython} -c "import shutil; shutil.rmtree('{toxinidir}/dist', ignore_errors=True)"
+    {envpython} -m build
     twine check --strict {toxinidir}/dist/*
-usedevelop = False
 
 [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} .