Enable WSGI module entrypoint for Ironic

This adds a wsgi entrypoint module which can be used with a wsgi runner,
such as uwsgi, to launch Ironic API processes without the need of a
separate script.

The legacy WSGI script is currently being installed by PBR, and as part
of the migration to a pyproject.yaml-compatible PBR, we cannot use the
wsgi-scripts plugin anymore, and will be removing the script installed
by it in a future Ironic release.

The new WSGI script, because it has statements at the module top-level,
cannot be autodocumented; we now exclude it.

Also we don't treat all warnings as errors in pdf docs builds to allow
the use of mock autosummary, starting with including the wsgi module.

Co-Authored-By: Doug Goldstein <cardoe@cardoe.com>
Change-Id: I584ac6a25c4e6cd9744a609b50d12b434a930dc6
This commit is contained in:
Jay Faulkner 2024-08-30 10:49:38 -07:00 committed by Riccardo Pittau
parent 1f740c8a90
commit 3db454f0ea
5 changed files with 51 additions and 4 deletions

View File

@ -411,7 +411,7 @@ fi
# Support entry points installation of console scripts # Support entry points installation of console scripts
IRONIC_BIN_DIR=$(get_python_exec_prefix) IRONIC_BIN_DIR=$(get_python_exec_prefix)
IRONIC_UWSGI_CONF=$IRONIC_CONF_DIR/ironic-uwsgi.ini IRONIC_UWSGI_CONF=$IRONIC_CONF_DIR/ironic-uwsgi.ini
IRONIC_UWSGI=$IRONIC_BIN_DIR/ironic-api-wsgi IRONIC_UWSGI=${IRONIC_UWSGI:-ironic.wsgi:application}
# Lets support IPv6 testing! # Lets support IPv6 testing!
IRONIC_IP_VERSION=${IRONIC_IP_VERSION:-${IP_VERSION:-4}} IRONIC_IP_VERSION=${IRONIC_IP_VERSION:-${IP_VERSION:-4}}
@ -1663,7 +1663,7 @@ function configure_ironic {
fi fi
# Adds uWSGI for Ironic API # Adds uWSGI for Ironic API
write_uwsgi_config "$IRONIC_UWSGI_CONF" "$IRONIC_UWSGI" "/baremetal" write_uwsgi_config "$IRONIC_UWSGI_CONF" "$IRONIC_UWSGI" "/baremetal" "" "ironic-api"
if [[ "$os_VENDOR" =~ (Debian|Ubuntu) ]]; then if [[ "$os_VENDOR" =~ (Debian|Ubuntu) ]]; then
# The groups change with newer libvirt. Older Ubuntu used # The groups change with newer libvirt. Older Ubuntu used

View File

@ -32,7 +32,9 @@ sys.path.insert(0, os.path.join(os.path.abspath('.'), '_exts'))
# Add any Sphinx extension module names here, as strings. They can be # Add any Sphinx extension module names here, as strings. They can be
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones. # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones.
extensions = ['sphinx.ext.viewcode', extensions = ['sphinx.ext.autodoc',
'sphinx.ext.autosummary',
'sphinx.ext.viewcode',
'sphinx.ext.graphviz', 'sphinx.ext.graphviz',
'sphinxcontrib.apidoc', 'sphinxcontrib.apidoc',
'sphinxcontrib.rsvgconverter', 'sphinxcontrib.rsvgconverter',
@ -62,6 +64,10 @@ autodoc_default_options = {
'special-members': '__call__', 'special-members': '__call__',
} }
autosummary_mock_imports = [
'ironic.wsgi',
]
redfish_interop_source = \ redfish_interop_source = \
'../../redfish-interop-profiles/OpenStackIronicProfile.v1_1_0.json' '../../redfish-interop-profiles/OpenStackIronicProfile.v1_1_0.json'
redfish_interop_output_dir = 'admin/drivers/redfish/' redfish_interop_output_dir = 'admin/drivers/redfish/'

23
ironic/wsgi/__init__.py Normal file
View File

@ -0,0 +1,23 @@
# 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.
"""WSGI application entry-point for Ironic API."""
import threading
from ironic.api import wsgi
application = None
lock = threading.Lock()
with lock:
if application is None:
application = wsgi.initialize_wsgi_app()

View File

@ -0,0 +1,18 @@
features:
- |
A new module, ``ironic.wsgi`` has been enabled as an entrypoint for WSGI
runners. For example, if using uWSGI then now instead of:
.. code-block:: ini
[uwsgi]
wsgi-file = /bin/ironic-api-wsgi
You can now use:
.. code-block:: ini
[uwsgi]
module = ironic.wsgi:application
Legacy installed wsgi scripts will be removed in a future version of Ironic.

View File

@ -100,7 +100,7 @@ commands = sphinx-build -b html doc/source doc/build/html
allowlist_externals = make allowlist_externals = make
deps = {[testenv:docs]deps} deps = {[testenv:docs]deps}
commands = commands =
sphinx-build -W -b latex doc/source doc/build/pdf sphinx-build -b latex doc/source doc/build/pdf
make -C doc/build/pdf make -C doc/build/pdf