CI: Add ansible-lint to tox
* Reworked tox pep8 into linters job, that runs: - pep8 - bandit - bashate - doc8 - yamllint - ansible-lint (validate-all-files.py + ansible-lint) * Skip E701 - missing galaxy_info in meta and E602 see [1]. * Skip E301 and E503 - followup later in a separate change * Added ansible-role-jobs to zuul.d/project.yaml which will run openstack-tox-linters job in check queue * Fixed remaining style issue * Made tox and docs reference the new env for linters * Dropped pype environment (not supported) [1]: https://github.com/ansible/ansible-lint/issues/457 Change-Id: I494b4b151804aac8173120e6c6e42bc2fdb00234
This commit is contained in:
parent
fe54fdbc34
commit
d8f31e0a5e
12
.ansible-lint
Normal file
12
.ansible-lint
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
use_default_rules: true
|
||||||
|
skip_list:
|
||||||
|
# [E701] galaxy_info missing in metadata
|
||||||
|
- '701'
|
||||||
|
# [E602] https://github.com/ansible/ansible-lint/issues/457
|
||||||
|
- '602'
|
||||||
|
# [E301] Commands should not change things if nothing needs doing
|
||||||
|
# TODO(mnasiadka): Fix tasks that fail this check in a later iteration
|
||||||
|
- '301'
|
||||||
|
# [E503] Tasks that run when changed should likely be handlers
|
||||||
|
# TODO(mnasiadka): Rework baremetal role to do handlers instead of when: *.changed
|
||||||
|
- '503'
|
@ -197,7 +197,7 @@
|
|||||||
- Restart prometheus-server container
|
- Restart prometheus-server container
|
||||||
vars:
|
vars:
|
||||||
base: "{{ node_custom_config }}/prometheus/"
|
base: "{{ node_custom_config }}/prometheus/"
|
||||||
service: "{{ prometheus_services['prometheus-server']}}"
|
service: "{{ prometheus_services['prometheus-server'] }}"
|
||||||
when:
|
when:
|
||||||
- inventory_hostname in groups[service.group]
|
- inventory_hostname in groups[service.group]
|
||||||
- service.enabled | bool
|
- service.enabled | bool
|
||||||
|
@ -28,6 +28,12 @@ so the only package you install is ``tox`` itself:
|
|||||||
For more information, see `the unit testing section of the Testing wiki page
|
For more information, see `the unit testing section of the Testing wiki page
|
||||||
<https://wiki.openstack.org/wiki/Testing#Unit_Tests>`_. For example:
|
<https://wiki.openstack.org/wiki/Testing#Unit_Tests>`_. For example:
|
||||||
|
|
||||||
|
To run the default set of tests:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
tox
|
||||||
|
|
||||||
To run the Python 3.7 tests:
|
To run the Python 3.7 tests:
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
@ -38,13 +44,13 @@ To run the style tests:
|
|||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
tox -e pep8
|
tox -e linters
|
||||||
|
|
||||||
To run multiple tests separate items by commas:
|
To run multiple tests separate items by commas:
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
tox -e py37,pep8
|
tox -e py37,linters
|
||||||
|
|
||||||
Running a subset of tests
|
Running a subset of tests
|
||||||
-------------------------
|
-------------------------
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
# linting
|
# linting
|
||||||
|
ansible-lint>=4.2.0 # MIT
|
||||||
bandit>=1.1.0 # Apache-2.0
|
bandit>=1.1.0 # Apache-2.0
|
||||||
bashate>=0.5.1 # Apache-2.0
|
bashate>=0.5.1 # Apache-2.0
|
||||||
doc8>=0.6.0 # Apache-2.0
|
doc8>=0.6.0 # Apache-2.0
|
||||||
hacking>=3.0.1,<3.1.0 # Apache-2.0
|
hacking>=3.0.1,<3.1.0 # Apache-2.0
|
||||||
|
yamllint>=1.22.0 #GPL3
|
||||||
|
|
||||||
# coverage testing
|
# coverage testing
|
||||||
coverage!=4.4,>=4.0 # Apache-2.0
|
coverage!=4.4,>=4.0 # Apache-2.0
|
||||||
|
88
tox.ini
88
tox.ini
@ -1,12 +1,12 @@
|
|||||||
[tox]
|
[tox]
|
||||||
minversion = 3.1
|
minversion = 3.1
|
||||||
skipsdist = True
|
skipsdist = True
|
||||||
envlist = py37,pep8,pypy
|
envlist = py37,linters
|
||||||
ignore_basepython_conflict = True
|
ignore_basepython_conflict = True
|
||||||
|
|
||||||
[testenv]
|
[testenv]
|
||||||
basepython = python3
|
basepython = python3
|
||||||
usedevelop=True
|
usedevelop = True
|
||||||
whitelist_externals = find
|
whitelist_externals = find
|
||||||
rm
|
rm
|
||||||
deps = -c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
deps = -c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
||||||
@ -36,25 +36,6 @@ commands =
|
|||||||
coverage html -d cover
|
coverage html -d cover
|
||||||
coverage xml -o cover/coverage.xml
|
coverage xml -o cover/coverage.xml
|
||||||
|
|
||||||
[testenv:pep8]
|
|
||||||
# sphinx needs to be installed to make doc8 work properly
|
|
||||||
deps =
|
|
||||||
{[testenv]deps}
|
|
||||||
-r{toxinidir}/doc/requirements.txt
|
|
||||||
yamllint
|
|
||||||
commands =
|
|
||||||
{toxinidir}/tools/run-bashate.sh
|
|
||||||
flake8 {posargs}
|
|
||||||
doc8 doc/source
|
|
||||||
doc8 -e '.yaml' releasenotes/notes/
|
|
||||||
python {toxinidir}/tools/validate-all-file.py
|
|
||||||
bandit --skip B303 -r ansible kolla_ansible tests tools
|
|
||||||
yamllint -s .
|
|
||||||
|
|
||||||
[testenv:bandit]
|
|
||||||
# B303: Use of insecure MD2, MD4, MD5, or SHA1 hash function.
|
|
||||||
commands = bandit --skip B303 -r ansible kolla_ansible tests tools
|
|
||||||
|
|
||||||
[testenv:venv]
|
[testenv:venv]
|
||||||
deps =
|
deps =
|
||||||
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
||||||
@ -74,7 +55,6 @@ commands =
|
|||||||
deps =
|
deps =
|
||||||
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
||||||
-r{toxinidir}/doc/requirements.txt
|
-r{toxinidir}/doc/requirements.txt
|
||||||
|
|
||||||
commands =
|
commands =
|
||||||
rm -rf deploy-guide/build
|
rm -rf deploy-guide/build
|
||||||
sphinx-build -a -E -W -d deploy-guide/build/doctrees --keep-going -b html deploy-guide/source deploy-guide/build/html
|
sphinx-build -a -E -W -d deploy-guide/build/doctrees --keep-going -b html deploy-guide/source deploy-guide/build/html
|
||||||
@ -95,6 +75,36 @@ commands =
|
|||||||
rm -rf releasenotes/build
|
rm -rf releasenotes/build
|
||||||
sphinx-build -a -E -W -d releasenotes/build/doctrees --keep-going -b html releasenotes/source releasenotes/build/html
|
sphinx-build -a -E -W -d releasenotes/build/doctrees --keep-going -b html releasenotes/source releasenotes/build/html
|
||||||
|
|
||||||
|
[testenv:lower-constraints]
|
||||||
|
deps =
|
||||||
|
-c{toxinidir}/lower-constraints.txt
|
||||||
|
-r{toxinidir}/test-requirements.txt
|
||||||
|
-r{toxinidir}/requirements.txt
|
||||||
|
|
||||||
|
[testenv:linters]
|
||||||
|
# Env vars and deps need to be defined in top level tox env
|
||||||
|
setenv =
|
||||||
|
ANSIBLE_LIBRARY = {toxinidir}/ansible/library
|
||||||
|
ANSIBLE_ACTION_PLUGINS = {toxinidir}/ansible/action_plugins
|
||||||
|
ANSIBLE_FILTER_PLUGINS = {toxinidir}/ansible/filter_plugins
|
||||||
|
deps =
|
||||||
|
-c{env:UPPER_CONSTRAINTS_FILE:https://releases.openstack.org/constraints/upper/master}
|
||||||
|
-r{toxinidir}/test-requirements.txt
|
||||||
|
-r{toxinidir}/doc/requirements.txt
|
||||||
|
whitelist_externals = bash
|
||||||
|
commands =
|
||||||
|
{[testenv:pep8]commands}
|
||||||
|
{[testenv:doc8]commands}
|
||||||
|
{[testenv:bandit]commands}
|
||||||
|
{[testenv:bashate]commands}
|
||||||
|
{[testenv:yamllint]commands}
|
||||||
|
{[testenv:ansible-lint]commands}
|
||||||
|
|
||||||
|
[testenv:pep8]
|
||||||
|
deps = {[testenv:linters]deps}
|
||||||
|
commands =
|
||||||
|
flake8 {posargs}
|
||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
show-source = True
|
show-source = True
|
||||||
# NOTE: Default ignore list is *not* empty!
|
# NOTE: Default ignore list is *not* empty!
|
||||||
@ -102,10 +112,32 @@ show-source = True
|
|||||||
# (W503 and W504 are incompatible and we need to choose one of them.
|
# (W503 and W504 are incompatible and we need to choose one of them.
|
||||||
# Existing codes follows W503, so we disable W504.):
|
# Existing codes follows W503, so we disable W504.):
|
||||||
ignore = W504
|
ignore = W504
|
||||||
exclude=.eggs,.git,.tox,doc
|
exclude = .eggs,.git,.tox,doc
|
||||||
|
|
||||||
[testenv:lower-constraints]
|
[testenv:doc8]
|
||||||
deps =
|
deps = {[testenv:linters]deps}
|
||||||
-c{toxinidir}/lower-constraints.txt
|
commands =
|
||||||
-r{toxinidir}/test-requirements.txt
|
doc8 doc/source
|
||||||
-r{toxinidir}/requirements.txt
|
doc8 -e '.yaml' releasenotes/notes/
|
||||||
|
|
||||||
|
[testenv:bashate]
|
||||||
|
deps = {[testenv:linters]deps}
|
||||||
|
commands =
|
||||||
|
bash -c "{toxinidir}/tools/run-bashate.sh"
|
||||||
|
|
||||||
|
[testenv:bandit]
|
||||||
|
# B303: Use of insecure MD2, MD4, MD5, or SHA1 hash function.
|
||||||
|
deps = {[testenv:linters]deps}
|
||||||
|
commands = bandit --skip B303 -r ansible kolla_ansible tests tools
|
||||||
|
|
||||||
|
[testenv:ansible-lint]
|
||||||
|
# Lint only code in ansible/* - ignore tests/ and roles/ used by CI
|
||||||
|
setenv = {[testenv:linters]setenv}
|
||||||
|
deps = {[testenv:linters]deps}
|
||||||
|
commands =
|
||||||
|
python {toxinidir}/tools/validate-all-file.py
|
||||||
|
ansible-lint -p --exclude {toxinidir}/tests --exclude {toxinidir}/roles
|
||||||
|
|
||||||
|
[testenv:yamllint]
|
||||||
|
deps = {[testenv:linters]deps}
|
||||||
|
commands = yamllint -s .
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
- openstack-cover-jobs
|
- openstack-cover-jobs
|
||||||
- openstack-lower-constraints-jobs
|
- openstack-lower-constraints-jobs
|
||||||
- openstack-python3-ussuri-jobs
|
- openstack-python3-ussuri-jobs
|
||||||
|
- ansible-role-jobs
|
||||||
- publish-openstack-docs-pti
|
- publish-openstack-docs-pti
|
||||||
- release-notes-jobs-python3
|
- release-notes-jobs-python3
|
||||||
- periodic-stable-jobs
|
- periodic-stable-jobs
|
||||||
|
Loading…
Reference in New Issue
Block a user