Force UTF-8 mode for testing
[mudpy.git] / tox.ini
diff --git a/tox.ini b/tox.ini
index c9d79fd..e62c385 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,39 +11,60 @@ 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
 #
+# 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
 # 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
-# py310... importlib._bootstrap raises ImportWarning
-#   "_SixMetaPathImporter.find_spec() not found; falling back to find_module()"
-#   but this can't be matched by message for unknown reasons
-# py310... pip._vendor.urllib3.connection and pip._vendor.urllib3.util.ssl_
-#   both raise DeprecationWarning "ssl module: PROTOCOL_TLS is deprecated" but
-#   this can't be matched by message because it contains a colon
+# 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
+# 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::DeprecationWarning:distutils.command.install, ignore::ImportWarning:importlib._bootstrap, ignore::DeprecationWarning:pip._vendor.urllib3.connection, ignore::DeprecationWarning:pip._vendor.urllib3.util.ssl_, 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
+    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:module 'sre_constants' is deprecated:DeprecationWarning:pip._vendor.pyparsing.core, ignore:module 'sre_constants' is deprecated:DeprecationWarning:pkg_resources._vendor.pyparsing
+    PYTHONUTF8 = 1
     VIRTUALENV_CREATOR = venv
 commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
+deps = {toxinidir}
 
 [testenv:bandit]
 description = check for potential security risks in source code
 deps = bandit
 commands = bandit -r mudpy -x mudpy/tests {posargs}
-usedevelop = False
 
 [testenv:codespell]
 description = find common spelling mistakes in code and documentation
 deps = codespell
 commands = codespell {posargs}
-usedevelop = False
 
 [testenv:demo]
 description = start an interactive demo with the sample config
@@ -59,15 +80,14 @@ commands =
     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.
+# files to include.
 description = generate hypertext documentation
 allowlist_externals = rm
 deps =
+    {toxinidir}
     build
     sphinx
 commands =
@@ -81,7 +101,6 @@ deps =
     flake8
     flake8-bugbear
 commands = flake8 {posargs}
-usedevelop = False
 
 [testenv:selftest_config]
 description = run the selftest with the included sample config
@@ -92,7 +111,9 @@ commands = mudpy_selftest etc/mudpy.yaml
 # 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 =
+    {toxinidir}
+    yamllint
 commands =
     mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
     yamllint --strict {posargs} .