usedevelop = True
# TODO(fungi) Switch this to "error" once the following are solved
#
-# py310... importlib._bootstrap raises ImportWarning:
-# _SixMetaPathImporter.find_spec() not found; falling back to find_module()
-# all... pip._vendor.packaging.version raises DeprecationWarning: Creating a
-# LegacyVersion has been deprecated and will be removed in the next major
-# release
-# 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 and setuptools both raise
-# DeprecationWarning: The distutils package is deprecated and slated for
-# removal in Python 3.12. Use setuptools or check PEP 632 for potential
-# alternatives
+# py310... 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 contains 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
+# 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
+# py310... wheel.bdist_wheel raises DeprecationWarning "The \"license_file\"
+# option is deprecated. Use \"license_files\" instead."
+# 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"
setenv =
- PYTHONWARNINGS = error, ignore:::importlib._bootstrap, ignore:::pip._vendor.packaging.version, ignore:::pip._vendor.packaging.specifiers, ignore:::pip._vendor.packaging.tags, ignore:::setuptools
+ PYTHONWARNINGS = error, ignore::FutureWarning:Cython.Compiler.Main, ignore::DeprecationWarning:setuptools.config, ignore::DeprecationWarning:distutils.command.install, ignore::ImportWarning:importlib._bootstrap, ignore::DeprecationWarning:pip._vendor.urllib3.connection, ignore::DeprecationWarning:pip._vendor.urllib3.util.ssl_, ignore:The "license_file" option is deprecated. Use "license_files" instead.:DeprecationWarning:wheel.bdist_wheel, 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
VIRTUALENV_CREATOR = venv
commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
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 --strict 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]
description = style checks and static analysis of source code
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
commands =