f0d39aa777
This change adds a basic bandit config for sahara. It can be invoked by running the tox environment for bandit; `$ tox -e bandit`. The tests are based on the default bandit configuration with a few blacklist tests as well. This is intended as a starting point for using bandit with sahara and it should be revisited to improve the testing as more is learned about the specific needs of the sahara code base. * adding bandit.yaml configuration * adding bandit to tox.ini * adding a requirements file for bandit tox environment Change-Id: I4b03f04dca80b146fdbae31a6b6011e78380d665
104 lines
2.9 KiB
INI
104 lines
2.9 KiB
INI
[tox]
|
|
envlist = py27,pep8
|
|
minversion = 1.6
|
|
skipsdist = True
|
|
|
|
[testenv]
|
|
usedevelop = True
|
|
install_command = pip install -U {opts} {packages}
|
|
setenv =
|
|
VIRTUAL_ENV={envdir}
|
|
DISCOVER_DIRECTORY=sahara/tests/unit
|
|
deps =
|
|
-r{toxinidir}/requirements.txt
|
|
-r{toxinidir}/test-requirements.txt
|
|
commands = bash tools/pretty_tox.sh '{posargs}'
|
|
whitelist_externals = bash
|
|
|
|
[testenv:integration]
|
|
setenv =
|
|
VIRTUAL_ENV={envdir}
|
|
DISCOVER_DIRECTORY=sahara/tests/integration
|
|
commands = bash tools/pretty_tox.sh '{posargs}'
|
|
|
|
[testenv:scenario]
|
|
setenv = VIRTUALENV={envdir}
|
|
commands = python {toxinidir}/sahara/tests/scenario/runner.py {posargs}
|
|
|
|
[testenv:py27-scenario-unit]
|
|
setenv =
|
|
VIRTUAL_ENV={envdir}
|
|
DISCOVER_DIRECTORY=sahara/tests/scenario_unit
|
|
commands = bash tools/pretty_tox.sh '{posargs}'
|
|
|
|
[testenv:cover]
|
|
commands = python setup.py testr --coverage --testr-args='{posargs}'
|
|
|
|
[tox:jenkins]
|
|
downloadcache = ~/cache/pip
|
|
|
|
[testenv:pep8]
|
|
commands =
|
|
flake8 {posargs}
|
|
# Check that .po and .pot files are valid:
|
|
bash -c "find sahara -type f -regex '.*\.pot?' -print0|xargs -0 -n 1 msgfmt --check-format -o /dev/null"
|
|
# Run bashate checks
|
|
bash -c "find sahara -iname '*.sh' -print0 | xargs -0 bashate"
|
|
|
|
[testenv:doc8]
|
|
deps =
|
|
-r{toxinidir}/requirements.txt
|
|
-r{toxinidir}/test-requirements.txt
|
|
doc8
|
|
commands = doc8 doc/source
|
|
|
|
[testenv:venv]
|
|
commands = {posargs}
|
|
|
|
[testenv:docs]
|
|
commands =
|
|
rm -rf doc/html doc/build
|
|
rm -rf doc/source/apidoc doc/source/api
|
|
python setup.py build_sphinx
|
|
whitelist_externals =
|
|
rm
|
|
|
|
[testenv:pylint]
|
|
setenv = VIRTUAL_ENV={envdir}
|
|
commands = bash tools/lintstack.sh
|
|
|
|
[testenv:genconfig]
|
|
commands =
|
|
oslo-config-generator --config-file tools/config/config-generator.sahara.conf \
|
|
--output-file etc/sahara/sahara.conf.sample
|
|
|
|
[testenv:pip-missing-reqs]
|
|
# do not install test-requirements as that will pollute the virtualenv for
|
|
# determining missing packages
|
|
# this also means that pip-missing-reqs must be installed separately, outside
|
|
# of the requirements.txt files
|
|
deps =
|
|
pip_missing_reqs
|
|
-r{toxinidir}/requirements.txt
|
|
commands = pip-missing-reqs -d --ignore-file=sahara/tests/* sahara
|
|
|
|
[testenv:debug]
|
|
# It runs tests from the specified dir (default is sahara/tests)
|
|
# in interactive mode, so, you could use pbr for tests debug.
|
|
# Example usage: tox -e debug -- -t sahara/tests/unit some.test.path
|
|
# http://docs.openstack.org/developer/oslotest/features.html#debugging-with-oslo-debug-helper
|
|
commands = oslo_debug_helper {posargs}
|
|
|
|
[testenv:bandit]
|
|
deps = -r{toxinidir}/test-requirements-bandit.txt
|
|
commands = bandit -c bandit.yaml -r sahara -n5 -p sahara_default
|
|
|
|
[flake8]
|
|
show-source = true
|
|
builtins = _
|
|
exclude=.venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,tools
|
|
|
|
[hacking]
|
|
import_exceptions = sahara.i18n._, sahara.i18n._LI, sahara.i18n._LW, sahara.i18n._LE, sahara.i18n._LC
|
|
local-check-factory = sahara.utils.hacking.checks.factory
|