diff --git a/.zuul.yaml b/.zuul.yaml index 03ee346..e63e2bc 100644 --- a/.zuul.yaml +++ b/.zuul.yaml @@ -4,14 +4,14 @@ release_python: python3 check: jobs: - - zuul-tox-docs + - zuul-nox-docs gate: jobs: - - zuul-tox-docs + - zuul-nox-docs promote: jobs: - - zuul-promote-docs + - zuul-promote-nox-docs release: jobs: - - zuul-publish-tox-docs + - zuul-publish-nox-docs - zuul-release-python diff --git a/noxfile.py b/noxfile.py new file mode 100644 index 0000000..431e883 --- /dev/null +++ b/noxfile.py @@ -0,0 +1,51 @@ +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + +import nox + + +nox.options.error_on_external_run = True +nox.options.reuse_existing_virtualenvs = True +nox.options.sessions = ["linters"] + + +@nox.session(python='3') +def bindep(session): + session.install('bindep') + session.run('bindep', 'test') + + +@nox.session(python='3') +def docs(session): + session.install('-r', 'doc/requirements.txt', + '-r', 'test-requirements.txt') + session.install('-e', '.') + session.run('sphinx-build', '-E', '-W', '-d', 'doc/build/doctrees', + '-b', 'html', 'doc/source/', 'doc/build/html') + + +@nox.session(python='3') +def linters(session): + session.install('-r', 'requirements.txt', + '-r', 'test-requirements.txt') + session.install('flake8') + session.run('flake8', *session.posargs) + session.run('bash', '-c', '"cd roles; find . -type f -regex ' + '\'.*.y[a]?ml\' -print0 | xargs -t -n1 -0 ansible-lint"') + + +@nox.session(python='3') +def venv(session): + session.install('-r', 'requirements.txt', + '-r', 'test-requirements.txt') + session.install('-e', '.') + session.run(*session.posargs) diff --git a/setup.cfg b/setup.cfg index 1ee3810..79c1ad9 100644 --- a/setup.cfg +++ b/setup.cfg @@ -25,3 +25,10 @@ all-files = 1 warning-is-error = 1 source-dir = doc/source build-dir = doc/build + +[flake8] +# These are ignored intentionally in openstack-infra projects; +# please don't submit patches that solely correct them or enable them. +ignore = E125,E129,H +show-source = True +exclude = .venv,.tox,.nox,dist,doc,build,*.egg diff --git a/tox.ini b/tox.ini index 78b05a7..45338d7 100644 --- a/tox.ini +++ b/tox.ini @@ -36,10 +36,3 @@ commands = [testenv:venv] commands = {posargs} - -[flake8] -# These are ignored intentionally in openstack-infra projects; -# please don't submit patches that solely correct them or enable them. -ignore = E125,E129,H -show-source = True -exclude = .venv,.tox,dist,doc,build,*.egg