From 20f1bec564f0d46a1169842669782fb93fec77ba Mon Sep 17 00:00:00 2001 From: bgartzi Date: Mon, 30 Oct 2023 11:12:31 +0100 Subject: [PATCH] env_process: Refactor Libvirtd debug log setup/cleanup into a Setuper Move the setup/cleanup steps of the Libvirtd debug log from the env_process.{pre,post}process into a Setuper subclass. The env_process setup_manager will call the setup/cleanup methods when appropriate. Signed-off-by: bgartzi --- virttest/env_process.py | 18 ++---------------- virttest/test_setup/libvirt_setup.py | 27 +++++++++++++++++++++++++++ 2 files changed, 29 insertions(+), 16 deletions(-) create mode 100644 virttest/test_setup/libvirt_setup.py diff --git a/virttest/env_process.py b/virttest/env_process.py index 01cad29831..ac3012d3fb 100644 --- a/virttest/env_process.py +++ b/virttest/env_process.py @@ -51,7 +51,7 @@ from virttest.test_setup.core import SetupManager from virttest.test_setup.os_posix import UlimitConfig from virttest.test_setup.networking import NetworkProxies, BridgeConfig - +from virttest.test_setup.libvirt_setup import LibvirtdDebugLogConfig # lazy imports for dependencies that are not needed in all modes of use from virttest._wrappers import lazy_import @@ -1096,23 +1096,12 @@ def preprocess(test, params, env): _setup_manager.initialize(test, params, env) _setup_manager.register(UlimitConfig) _setup_manager.register(NetworkProxies) + _setup_manager.register(LibvirtdDebugLogConfig) _setup_manager.register(BridgeConfig) _setup_manager.do_setup() vm_type = params.get("vm_type") - if vm_type == "libvirt": - if params.get("enable_libvirtd_debug_log", "yes") == "yes": - # By default log the info level - log_level = params.get("libvirtd_debug_level", "2") - log_file = params.get("libvirtd_debug_file", "") - log_filters = params.get("libvirtd_debug_filters", "%s:*" % log_level) - log_permission = params.get("libvirtd_log_permission") - libvirtd_debug_log = test_setup.LibvirtdDebugLog( - test, log_level, log_file, log_filters, log_permission - ) - libvirtd_debug_log.enable() - base_dir = data_dir.get_data_dir() if params.get("storage_type") == "iscsi": iscsidev = qemu_storage.Iscsidev(params, base_dir, "iscsi") @@ -1993,9 +1982,6 @@ def postprocess(test, params, env): except Exception as details: err += "\nPolkit cleanup: %s" % str(details).replace("\\n", "\n ") LOG.error("Unexpected error: %s" % details) - if params.get("enable_libvirtd_debug_log", "yes") == "yes": - libvirtd_debug_log = test_setup.LibvirtdDebugLog(test) - libvirtd_debug_log.disable() # Execute any post_commands if params.get("post_command"): diff --git a/virttest/test_setup/libvirt_setup.py b/virttest/test_setup/libvirt_setup.py new file mode 100644 index 0000000000..882ab8de29 --- /dev/null +++ b/virttest/test_setup/libvirt_setup.py @@ -0,0 +1,27 @@ +from virttest.test_setup.core import Setuper +from virttest import test_setup + + +class LibvirtdDebugLogConfig(Setuper): + def setup(self): + if ( + self.params.get("vm_type") == "libvirt" + and self.params.get("enable_libvirtd_debug_log", "yes") == "yes" + ): + # By default log the info level + log_level = self.params.get("libvirtd_debug_level", "2") + log_file = self.params.get("libvirtd_debug_file", "") + log_filters = self.params.get("libvirtd_debug_filters", f"{log_level}:*") + log_permission = self.params.get("libvirtd_log_permission") + libvirtd_debug_log = test_setup.LibvirtdDebugLog( + self.test, log_level, log_file, log_filters, log_permission + ) + libvirtd_debug_log.enable() + + def cleanup(self): + if ( + self.params.get("vm_type") == "libvirt" + and self.params.get("enable_libvirtd_debug_log", "yes") == "yes" + ): + libvirtd_debug_log = test_setup.LibvirtdDebugLog(self.test) + libvirtd_debug_log.disable()