Convert docs from tox to nox

Using https://review.opendev.org/c/zuul/zuul/+/867057/13 and
https://review.opendev.org/c/zuul/zuul/+/868229/1 as rough templates,
introduced a noxfile and switched over the docs jobs to use nox
instead of tox.

Change-Id: I25e653189f37d28d4947ac90a6f5293939377192
This commit is contained in:
Michael Kelly 2023-02-24 20:45:41 -08:00
parent ac2488d242
commit b653e6e20a
No known key found for this signature in database
GPG Key ID: 77F7FE93040ECF3E
3 changed files with 52 additions and 3 deletions

2
.gitignore vendored
View File

@ -8,3 +8,5 @@ id_rsa
id_rsa.pub id_rsa.pub
*.patch *.patch
*.egg-info/ *.egg-info/
.nox
.tox

View File

@ -98,20 +98,20 @@
check: check:
jobs: jobs:
- tox-linters - tox-linters
- zuul-tox-docs - zuul-nox-docs
- zuul-operator-build-image - zuul-operator-build-image
- zuul-operator-functional-k8s: - zuul-operator-functional-k8s:
dependencies: zuul-operator-build-image dependencies: zuul-operator-build-image
gate: gate:
jobs: jobs:
- tox-linters - tox-linters
- zuul-tox-docs - zuul-nox-docs
- zuul-operator-upload-image - zuul-operator-upload-image
- zuul-operator-functional-k8s: - zuul-operator-functional-k8s:
dependencies: zuul-operator-upload-image dependencies: zuul-operator-upload-image
promote: promote:
jobs: jobs:
- zuul-promote-docs - zuul-promote-nox-docs
- zuul-operator-promote-image - zuul-operator-promote-image
release: release:
jobs: jobs:

47
noxfile.py Normal file
View File

@ -0,0 +1,47 @@
# Copyright 2022 Acme Gating, LLC
#
# 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 os
import nox
nox.options.error_on_external_run = True
nox.options.reuse_existing_virtualenvs = True
nox.options.sessions = ["tests-3", "linters"]
def set_env(session, var, default):
session.env[var] = os.environ.get(var, default)
def set_standard_env_vars(session):
set_env(session, 'OS_LOG_CAPTURE', '1')
set_env(session, 'OS_STDERR_CAPTURE', '1')
set_env(session, 'OS_STDOUT_CAPTURE', '1')
set_env(session, 'OS_TEST_TIMEOUT', '360')
# Set PYTHONTRACEMALLOC to a value greater than 0 in the calling env
# to get tracebacks of that depth for ResourceWarnings. Disabled by
# default as this consumes more resources and is slow.
set_env(session, 'PYTHONTRACEMALLOC', '0')
@nox.session(python='3')
def docs(session):
set_standard_env_vars(session)
session.install('-r', 'doc/requirements.txt')
session.install('-e', '.')
session.run('sphinx-build', '-E', '-W', '-d', 'doc/build/doctrees',
'-b', 'html', 'doc/source/', 'doc/build/html')