658c68b593
As discussed in TC PTG[1] and TC resolution[2], we are dropping the lower-constraints.txt file and its testing. We will keep lower bounds in the requirements.txt file but with a note that these are not tested lower bounds and we try our best to keep them updated. [1] https://etherpad.opendev.org/p/tc-zed-ptg#L326 [2] https://governance.openstack.org/tc/resolutions/20220414-drop-lower-constraints.html#proposal Change-Id: Ibd8664001aa3960f3994340cfd31683d8514a280
178 lines
4.8 KiB
INI
178 lines
4.8 KiB
INI
[tox]
|
|
envlist = py38,pep8,cover
|
|
minversion = 2.7
|
|
skipsdist = True
|
|
|
|
[testenv]
|
|
basepython = python3
|
|
setenv =
|
|
VIRTUAL_ENV={envdir}
|
|
OS_TEST_PATH=monasca_api/tests
|
|
passenv = *_proxy
|
|
*_PROXY
|
|
usedevelop = True
|
|
install_command = pip install {opts} {packages}
|
|
deps =
|
|
-c{env:TOX_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
|
-r{toxinidir}/test-requirements.txt
|
|
-r{toxinidir}/requirements.txt
|
|
.[influxdb,cassandra]
|
|
whitelist_externals = bash
|
|
find
|
|
rm
|
|
commands =
|
|
find . -type f -name "*.pyc" -delete
|
|
stestr run {posargs}
|
|
|
|
[testenv:cover]
|
|
description = Calculates code coverage
|
|
setenv =
|
|
PYTHON=coverage run --source monasca_api --parallel-mode
|
|
commands =
|
|
stestr run {posargs}
|
|
coverage combine
|
|
coverage html -d cover
|
|
coverage xml -o cover/coverage.xml
|
|
|
|
[testenv:debug]
|
|
commands =
|
|
oslo_debug_helper -t ./monasca_api/tests {posargs}
|
|
|
|
[testenv:flake8]
|
|
skip_install = True
|
|
usedevelop = False
|
|
commands =
|
|
flake8 monasca_api
|
|
|
|
[testenv:bandit]
|
|
skip_install = True
|
|
usedevelop = False
|
|
commands =
|
|
# B101(assert_ussed) - API uses asserts because of performance reasons
|
|
# B303 - Fingerprint class uses SHA1 to map fingerprints to alembic revisions.
|
|
bandit -r monasca_api -n5 -s B101,B303 -x monasca_api/tests
|
|
|
|
[testenv:bashate]
|
|
skip_install = True
|
|
usedevelop = False
|
|
commands = bash {toxinidir}/tools/bashate.sh
|
|
|
|
[testenv:pep8]
|
|
commands =
|
|
{[testenv:flake8]commands}
|
|
{[testenv:bandit]commands}
|
|
{[testenv:bashate]commands}
|
|
{[testenv:checkniceness]commands}
|
|
|
|
[testenv:docs]
|
|
deps = -c{env:TOX_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
|
-r{toxinidir}/doc/requirements.txt
|
|
description = Builds api-ref, api-guide, releasenotes and devdocs
|
|
commands =
|
|
{[testenv:devdocs]commands}
|
|
{[testenv:api-ref]commands}
|
|
{[testenv:releasenotes]commands}
|
|
|
|
[testenv:pdf-docs]
|
|
deps = {[testenv:docs]deps}
|
|
envdir = {toxworkdir}/docs
|
|
whitelist_externals =
|
|
make
|
|
rm
|
|
commands =
|
|
rm -rf doc/build/pdf
|
|
sphinx-build -W -b latex doc/source doc/build/pdf
|
|
make -C doc/build/pdf
|
|
|
|
[testenv:api-ref]
|
|
deps = {[testenv:docs]deps}
|
|
description = Called from CI scripts to test and publish the API Ref
|
|
commands =
|
|
rm -rf api-ref/build
|
|
{[testenv:checkjson]commands}
|
|
sphinx-build -W -b html -d api-ref/build/doctrees \
|
|
api-ref/source api-ref/build/html
|
|
|
|
[testenv:releasenotes]
|
|
deps = {[testenv:docs]deps}
|
|
description = Called from CI script to test and publish the Release Notes
|
|
commands =
|
|
rm -rf releasenotes/build
|
|
sphinx-build -a -E -W -d releasenotes/build/doctrees -b html \
|
|
releasenotes/source releasenotes/build/html
|
|
|
|
[testenv:devdocs]
|
|
deps = {[testenv:docs]deps}
|
|
description = Builds developer documentation
|
|
commands =
|
|
rm -rf doc/build doc/source/contributor/api
|
|
{[testenv:checkjson]commands}
|
|
python setup.py build_sphinx
|
|
|
|
[testenv:checkniceness]
|
|
skip_install = True
|
|
usedevelop = False
|
|
description = Validates (pep-like) documenation
|
|
commands =
|
|
rm -rf {toxinidir}/doc/source/contributor/api {toxinidir}/doc/build \
|
|
{toxinidir}/api-ref/build {toxinidir}/releasenotes/build
|
|
doc8 --file-encoding utf-8 {toxinidir}/doc
|
|
doc8 --file-encoding utf-8 {toxinidir}/api-ref
|
|
doc8 --file-encoding utf-8 {toxinidir}/releasenotes
|
|
|
|
[testenv:checkjson]
|
|
description = Validates all json samples inside doc folder
|
|
deps =
|
|
skip_install = True
|
|
usedevelop = False
|
|
whitelist_externals =
|
|
python
|
|
bash
|
|
commands =
|
|
bash -c "! find doc/ -type f -name *.json | xargs grep -U -n $'\r'"
|
|
bash -c '! find doc/ -type f -name *.json | \
|
|
xargs -t -n1 python -m json.tool 2>&1 > /dev/null | grep -B1 -v ^python'
|
|
|
|
[testenv:genconfig]
|
|
description = Generates sample configuration file for monasca-api
|
|
commands = oslo-config-generator --config-file=config-generator/monasca-api.conf
|
|
|
|
[testenv:genpolicy]
|
|
description = Generates sample policy.yaml file for monasca-api
|
|
commands = oslopolicy-sample-generator --config-file=config-generator/policy.conf
|
|
|
|
[testenv:venv]
|
|
commands = {posargs}
|
|
|
|
[testenv:bindep]
|
|
deps = bindep
|
|
commands = bindep test
|
|
|
|
[flake8]
|
|
# TODO: ignored checks should be enabled in the future
|
|
# H201 no 'except:' at least use 'except Exception:'
|
|
# H302 import only modules
|
|
# H405 multi line docstring summary not separated with an empty line
|
|
# W504 line break after binary operator
|
|
ignore = F821,H201,H302,H405,W504
|
|
# H106: Don't put vim configuration in source files
|
|
# H203: Use assertIs(Not)None to check for None
|
|
# H204: Use assert(Not)Equal to check for equality.
|
|
# H205: Use assert(Greater|Less)(Equal) for comparison.
|
|
enable-extensions=H106,H203,H204,H205
|
|
max-complexity = 50
|
|
max-line-length = 100
|
|
builtins = _
|
|
exclude=.venv,.git,.tox,dist,doc,*lib/python*,*egg,tools,build
|
|
show-source = True
|
|
|
|
[hacking]
|
|
local-check-factory = monasca_api.hacking.checks.factory
|
|
import_exceptions =
|
|
six.moves
|
|
|
|
[flake8:local-plugins]
|
|
extension =
|
|
B319 = checks:no_xrange
|
|
paths = ./monasca_api/hacking
|