b7e276349d
Using "python setup.py check -r -s" method of checking the package has been deprecated with the new recommendation to build the sdist and wheel, then running "twine check" against the output. Luckily, there is already a job that covers this that only runs when the README, setup.py, or setup.cfg files change, making running this in the pep8 job redundant. This covered by the test-release-openstack-python3 that is defined in the publish-to-pypi-python3 template. More details can be found in this mailing list post: http://lists.openstack.org/pipermail/openstack-dev/2018-October/136136.html Change-Id: Iaea98becbcc6877d8413a08a62d4427b11598fd3 Signed-off-by: Sean McGinnis <sean.mcginnis@gmail.com>
204 lines
5.7 KiB
INI
204 lines
5.7 KiB
INI
[tox]
|
|
envlist = pep8,py27,py35,py3-dj111,releasenotes,npm
|
|
minversion = 2.3.2
|
|
skipsdist = True
|
|
|
|
[testenv]
|
|
install_command = pip install {opts} {packages}
|
|
usedevelop = True
|
|
setenv =
|
|
VIRTUAL_ENV={envdir}
|
|
whitelist_externals =
|
|
bash
|
|
find
|
|
deps =
|
|
-c{env:UPPER_CONSTRAINTS_FILE:https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt}
|
|
-r{toxinidir}/test-requirements.txt
|
|
-r{toxinidir}/requirements.txt
|
|
commands = {[unit_tests]commands}
|
|
|
|
[unit_tests]
|
|
commands =
|
|
find . -type f -name "*.pyc" -delete
|
|
bash {toxinidir}/tools/unit_tests.sh {envpython} {toxinidir} {posargs}
|
|
|
|
[testenv:py35]
|
|
setenv =
|
|
PYTHONUNBUFFERED = 1
|
|
{[testenv]setenv}
|
|
|
|
[testenv:py3-dj21]
|
|
basepython = python3
|
|
commands =
|
|
pip install django>=2.1<2.2
|
|
{[unit_tests]commands}
|
|
|
|
[testenv:py3-dj111]
|
|
basepython = python3
|
|
commands =
|
|
pip install django>=1.11,<2
|
|
{[unit_tests]commands}
|
|
|
|
[testenv:lower-constraints]
|
|
basepython = python3
|
|
deps =
|
|
-c{toxinidir}/lower-constraints.txt
|
|
-r{toxinidir}/test-requirements.txt
|
|
-r{toxinidir}/requirements.txt
|
|
|
|
[testenv:venv]
|
|
basepython = python3
|
|
commands = {posargs}
|
|
|
|
[testenv:pep8]
|
|
basepython = python3
|
|
# sphinx (precisely Pygments) needs to be installed to make doc8 work properly
|
|
deps =
|
|
{[testenv]deps}
|
|
-r{toxinidir}/doc/requirements.txt
|
|
commands =
|
|
flake8 {posargs}
|
|
{envpython} {toxinidir}/manage.py extract_messages --verbosity 0 --check-only
|
|
bash {toxinidir}/tools/find_executables.sh
|
|
doc8 doc/source releasenotes/source releasenotes/notes
|
|
|
|
[testenv:cover]
|
|
basepython = python3
|
|
commands =
|
|
coverage erase
|
|
coverage run {toxinidir}/manage.py test horizon --settings=horizon.test.settings {posargs}
|
|
coverage run -a {toxinidir}/manage.py test openstack_dashboard --settings=openstack_dashboard.test.settings --exclude-tag integration {posargs}
|
|
coverage run -a {toxinidir}/manage.py test openstack_auth --settings=openstack_auth.tests.settings {posargs}
|
|
coverage xml
|
|
coverage html
|
|
|
|
[testenv:selenium]
|
|
basepython = python3
|
|
setenv =
|
|
{[testenv]setenv}
|
|
WITH_SELENIUM=1
|
|
SKIP_UNITTESTS=1
|
|
commands = {[unit_tests]commands}
|
|
|
|
[testenv:selenium-headless]
|
|
basepython = python3
|
|
setenv =
|
|
{[testenv]setenv}
|
|
SELENIUM_HEADLESS=1
|
|
WITH_SELENIUM=1
|
|
SKIP_UNITTESTS=1
|
|
commands = {[unit_tests]commands}
|
|
|
|
[testenv:selenium-phantomjs]
|
|
basepython = python3
|
|
setenv =
|
|
{[testenv]setenv}
|
|
SELENIUM_PHANTOMJS=1
|
|
WITH_SELENIUM=1
|
|
SKIP_UNITTESTS=1
|
|
commands = {[unit_tests]commands}
|
|
|
|
[testenv:py27integration]
|
|
# Run integration tests only
|
|
passenv = AVCONV_INSTALLED
|
|
setenv =
|
|
PYTHONHASHSEED=0
|
|
INTEGRATION_TESTS=1
|
|
SELENIUM_HEADLESS=1
|
|
basepython = python2.7
|
|
commands = {envpython} {toxinidir}/manage.py test openstack_dashboard --settings=openstack_dashboard.test.settings --verbosity 2 --tag integration {posargs}
|
|
|
|
[testenv:npm]
|
|
basepython = python3
|
|
passenv =
|
|
HOME
|
|
DISPLAY
|
|
commands =
|
|
nodeenv -p
|
|
npm install
|
|
npm run {posargs:test}
|
|
|
|
[testenv:tests_system_packages]
|
|
basepython = python3
|
|
# Provide an environment for system packagers that dont want anything from pip
|
|
# Any extra deps needed for this env can be passed by setting TOX_EXTRA_DEPS
|
|
sitepackages = True
|
|
passenv = TOX_EXTRA_DEPS http_proxy HTTP_PROXY https_proxy HTTPS_PROXY no_proxy NO_PROXY
|
|
# Sets deps to an empty list so nothing is installed from pip
|
|
deps =
|
|
commands =
|
|
pip install -U {env:TOX_EXTRA_DEPS:}
|
|
{[unit_tests]commands}
|
|
|
|
[testenv:docs]
|
|
basepython = python3
|
|
# We need to install horizon dependecies to build module references
|
|
deps =
|
|
-c{env:UPPER_CONSTRAINTS_FILE:https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt}
|
|
-r{toxinidir}/requirements.txt
|
|
-r{toxinidir}/doc/requirements.txt
|
|
commands =
|
|
sphinx-build -W -b html doc/source doc/build/html
|
|
|
|
[testenv:releasenotes]
|
|
basepython = python3
|
|
# There is no need to install horizon.
|
|
usedevelop = False
|
|
deps =
|
|
-c{env:UPPER_CONSTRAINTS_FILE:https://git.openstack.org/cgit/openstack/requirements/plain/upper-constraints.txt}
|
|
-r{toxinidir}/doc/requirements.txt
|
|
commands =
|
|
sphinx-build -a -E -W -d releasenotes/build/doctrees -b html releasenotes/source releasenotes/build/html
|
|
|
|
[testenv:manage]
|
|
basepython = python3
|
|
# we don't need to install test-requirements.txt
|
|
# modules in requirements.txt are installed due to usedevelop=True
|
|
# so 'deps' can be empty.
|
|
deps =
|
|
commands = {envpython} {toxinidir}/manage.py {posargs}
|
|
|
|
[testenv:runserver]
|
|
basepython = python3
|
|
commands = {envpython} {toxinidir}/manage.py runserver {posargs}
|
|
|
|
[testenv:bandit]
|
|
basepython = python3
|
|
commands = bandit -r horizon openstack_auth openstack_dashboard -n5 -x tests -ll
|
|
|
|
[testenv:bandit-baseline]
|
|
envdir = {toxworkdir}/bandit
|
|
basepython = python3
|
|
|
|
[flake8]
|
|
filename = *.py,django.wsgi
|
|
exclude = .git,.tox,dist,*lib/python*,*egg,build,panel_template,dash_template,local_settings.py,*/local/*,*/test/test_plugins/*,.ropeproject,node_modules,openstack_dashboard/enabled/*
|
|
ignore =
|
|
# Enable the following hacking rules which are disabled by default
|
|
# H106 Do not 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.
|
|
# H904 Delay string interpolations at logging calls.
|
|
enable-extensions=H106,H203,H204,H205,H904
|
|
max-complexity = 20
|
|
|
|
# flake8-import-order configurations
|
|
import-order-style = pep8
|
|
application-import-names = horizon,openstack_dashboard
|
|
|
|
[hacking]
|
|
local-check-factory = horizon.hacking.checks.factory
|
|
commands = bandit-baseline -r horizon openstack_auth openstack_dashboard -n5 -x tests -ii -ll
|
|
|
|
[doc8]
|
|
# File extensions to check
|
|
extensions = .rst, .yaml
|
|
# Maximal line length should be 80 but we have some overlong lines.
|
|
# Let's not get far more in.
|
|
max-line-length = 80
|
|
# Disable some doc8 checks:
|
|
# D000: Check RST validity
|
|
# - cannot handle "none" for code-block directive
|
|
ignore = D000
|