Update warning filter for SetupTools and filelock
[mudpy.git] / tox.ini
diff --git a/tox.ini b/tox.ini
index cfade32..5a1a808 100644 (file)
--- a/tox.ini
+++ b/tox.ini
@@ -12,28 +12,48 @@ ignore_basepython_conflict = True
 description = run the functional selftest with optimized configuration
 basepython = python3
 usedevelop = True
-install_command = pip install {opts} {packages}
-# TODO(fungi) Switch this to "error" and remove env-specific copies once
-# https://github.com/pypa/setuptools/issues/2086 is 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... 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
+# 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."
+# 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"
+# 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
+# filelock raises DeprecationWarning "use poll_interval instead of
+#   poll_intervall"
 setenv =
-    PYTHONWARNINGS=default::DeprecationWarning
-    VIRTUALENV_CREATOR=venv
+    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:use poll_interval instead of poll_intervall:DeprecationWarning
+    VIRTUALENV_CREATOR = venv
 commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
 
 [testenv:bandit]
-setenv =
-    PYTHONWARNINGS=error
 description = check for potential security risks in source code
 deps = bandit
 commands = bandit -r mudpy -x mudpy/tests {posargs}
 usedevelop = False
 
 [testenv:codespell]
-setenv =
-    PYTHONWARNINGS=error
 description = find common spelling mistakes in code and documentation
 deps = codespell
 commands = codespell {posargs}
@@ -47,30 +67,29 @@ commands = mudpy {posargs}
 description = build release artifacts and check for conformance
 allowlist_externals = rm
 deps =
-    pbr
+    build
     twine
-    wheel
 commands =
-    rm -fr dist
-    python setup.py bdist_wheel sdist
-    twine check dist/*
+    rm -fr {toxinidir}/dist
+    python -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. Keep usedevelop on so that the project dependencies will be
+# installed in the venv.
 description = generate hypertext documentation
 allowlist_externals = rm
 deps =
-    -r{toxinidir}/requirements.txt
-    -r{toxinidir}/doc/requirements.txt
+    build
+    sphinx
 commands =
-    rm -fr doc/build
-    python setup.py sdist
+    rm -fr {toxinidir}/doc/build
+    python -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]
-setenv =
-    PYTHONWARNINGS=error
 description = style checks and static analysis of source code
 deps =
     flake8
@@ -83,13 +102,15 @@ description = run the selftest with the included sample config
 commands = mudpy_selftest etc/mudpy.yaml
 
 [testenv:yamllint]
-setenv =
-    PYTHONWARNINGS=error
+# 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
-commands = yamllint --strict {posargs} .
-usedevelop = False
+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