Use consistent spacing in tox variables and lists
[mudpy.git] / tox.ini
diff --git a/tox.ini b/tox.ini
index 98fa5ec..7cbc5e4 100644 (file)
--- a/tox.ini
+++ b/tox.ini
@@ -1,47 +1,88 @@
-# Copyright (c) 2016-2018 Jeremy Stanley <fungi@yuggoth.org>. Permission
-# to use, copy, modify, and distribute this software is granted under
-# terms provided in the LICENSE file distributed with this software.
+# Copyright (c) 2016-2021 mudpy authors. Permission to use, copy,
+# modify, and distribute this software is granted under terms
+# provided in the LICENSE file distributed with this software.
 
 [tox]
-minversion = 2.0
-envlist = dist, docs, flake8, yamllint
+minversion = 3.18
+envlist = bandit, codespell, dist, docs, flake8, yamllint, selftest_config, py3
 skipsdist = True
+ignore_basepython_conflict = True
 
 [testenv]
+description = run the functional selftest with optimized configuration
 basepython = python3
 usedevelop = True
-install_command = pip install {opts} {packages}
+# 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
 setenv =
     PYTHONWARNINGS=default::DeprecationWarning
-deps = -r{toxinidir}/test-requirements.txt
+    VIRTUALENV_CREATOR = venv
 commands = mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
 
+[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
+commands = mudpy {posargs}
+
 [testenv:dist]
-whitelist_externals = rm
+description = build release artifacts and check for conformance
+allowlist_externals = rm
 deps =
-    docutils
     pbr
+    twine
+    wheel
 commands =
     rm -fr dist
-    python setup.py check --restructuredtext --strict
     python setup.py bdist_wheel sdist
+    twine check --strict dist/*
+usedevelop = False
 
 [testenv:docs]
-whitelist_externals = rm
-deps = -r{toxinidir}/doc/requirements.txt
+description = generate hypertext documentation
+allowlist_externals = rm
+deps =
+    -r{toxinidir}/requirements.txt
+    -r{toxinidir}/doc/requirements.txt
 commands =
     rm -fr doc/build
+    python setup.py 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
 commands = flake8 {posargs}
+usedevelop = False
 
-[testenv:yamllint]
-commands = yamllint {posargs} .
+[testenv:selftest_config]
+description = run the selftest with the included sample config
+commands = mudpy_selftest etc/mudpy.yaml
 
-[testenv:venv]
-commands = {posargs}
+[testenv:yamllint]
+description = test data files for correct syntax and formatting
+deps = yamllint
+commands =
+    mudpy_selftest mudpy/tests/fixtures/test_daemon.yaml
+    yamllint --strict {posargs} .
 
 [flake8]
 show-source = True
-exclude=.venv,.git,.tox,*lib/python*,*egg,build
+exclude = .git, .tox, *lib/python*, *egg, build