X-Git-Url: https://mudpy.org/gitweb?p=mudpy.git;a=blobdiff_plain;f=tox.ini;h=f9fd3933820bd2829927fff4d1514bba0f85de25;hp=7cc7b591b6f8738d1f8465291c88a31d8e92c182;hb=HEAD;hpb=f74875e196c063100da6081c11d05f817e49ed60 diff --git a/tox.ini b/tox.ini index 7cc7b59..33c4fb9 100644 --- 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,29 +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 -# https://github.com/pypa/setuptools/issues/2086 and -# https://github.com/pypa/setuptools/issues/2466 are 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... 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=default::DeprecationWarning - VIRTUALENV_CREATOR=venv + 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 @@ -41,48 +63,50 @@ 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 dist - python setup.py bdist_wheel sdist - twine check --strict dist/* -usedevelop = False + {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 = - -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} . [flake8] show-source = True -exclude=.git,.tox,*lib/python*,*egg,build +exclude = .git, .tox, *lib/python*, *egg, build