From 2373a6f182a30891e3749b7bd733c1b4380c3d85 Mon Sep 17 00:00:00 2001 From: moe-ad Date: Wed, 11 Dec 2024 14:19:26 +0100 Subject: [PATCH] fix: modified function checking server closure after sphinx gallery execution --- doc/source/conf.py | 42 +++++------------------------- requirements/requirements_docs.txt | 1 - 2 files changed, 6 insertions(+), 37 deletions(-) diff --git a/doc/source/conf.py b/doc/source/conf.py index 24d83d908e..a5721b5995 100644 --- a/doc/source/conf.py +++ b/doc/source/conf.py @@ -1,12 +1,10 @@ import os -import sys from glob import glob from datetime import datetime import numpy as np import pyvista import sphinx -from sphinx.util import logging from ansys.dpf.core import __version__, server, server_factory from ansys.dpf.core.examples import get_example_required_minimum_dpf_version from ansys_sphinx_theme import ansys_favicon, get_version_match, pyansys_logo_light_mode, pyansys_logo_dark_mode @@ -331,37 +329,15 @@ def reset_servers(gallery_conf, fname, when): def close_live_servers_and_processes(app: sphinx.application.Sphinx) -> None: - from ansys.dpf.core import server, _server_instances - import copy + # Adapted from reset_servers() function, so this can be called after + # sphinx gallery finishes execution import psutil + from ansys.dpf.core import server import gc - gc.collect - - # Server instances are different from processes. - # Ideally no running servers => no running processes - # Server instances should be closed first - running_servers = sum([1 if instance().live else 0 for instance in _server_instances]) - if running_servers: - print(f"{running_servers} live dpf servers found") - print("Closing servers") - - copy_instances = copy.deepcopy(_server_instances) - for instance in copy_instances: - try: - instance_object = instance() - if hasattr(instance_object, "shutdown"): - instance_object.shutdown() - except Exception as e: - print(e.args) - pass - server.shutdown_global_server() - running_servers = sum([1 if instance().live else 0 for instance in _server_instances]) - print(f"Found {running_servers} live dpf servers after closing") - else: - print("No live dpf servers found") - - # Subsequently check running processes and close + gc.collect() + server.shutdown_all_session_servers() + proc_name = "Ans.Dpf.Grpc" nb_procs = 0 for proc in psutil.process_iter(): @@ -373,12 +349,6 @@ def close_live_servers_and_processes(app: sphinx.application.Sphinx) -> None: except psutil.NoSuchProcess: pass - # Check if processes were actually killed - if nb_procs: - print(f"Killed {nb_procs} {proc_name} processes.") - else: - print(f"No processes were found running") - def setup(app: sphinx.application.Sphinx) -> None: """ Run hook function(s) during the documentation build. diff --git a/requirements/requirements_docs.txt b/requirements/requirements_docs.txt index 8e283d93be..aa8c1c6025 100644 --- a/requirements/requirements_docs.txt +++ b/requirements/requirements_docs.txt @@ -15,4 +15,3 @@ sphinx-reredirects==0.1.3 sphinx_design==0.6.1 sphinxcontrib-napoleon==0.7 vtk==9.3.1 -jupyterlab==4.3.1