From 803abef4dc4811e69381a1182bafa495a28ccfc8 Mon Sep 17 00:00:00 2001 From: Freddie Akeroyd Date: Thu, 19 Dec 2024 00:13:15 +0000 Subject: [PATCH] Handle no admin process spawn better --- .../ibex_install_utils/admin_runner.py | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/installation_and_upgrade/ibex_install_utils/admin_runner.py b/installation_and_upgrade/ibex_install_utils/admin_runner.py index 8624a39..1e78ee0 100644 --- a/installation_and_upgrade/ibex_install_utils/admin_runner.py +++ b/installation_and_upgrade/ibex_install_utils/admin_runner.py @@ -27,10 +27,14 @@ def run_command(command: str, parameters: str, expected_return_val: int | None = lpFile=command, lpParameters=parameters, ) - - win32event.WaitForSingleObject(process_info["hProcess"], 600000) - ret = win32process.GetExitCodeProcess(process_info["hProcess"]) - win32api.CloseHandle(process_info["hProcess"]) + ret = None + try: + win32event.WaitForSingleObject(process_info["hProcess"], 600000) + ret = win32process.GetExitCodeProcess(process_info["hProcess"]) + win32api.CloseHandle(process_info["hProcess"]) + except Exception as e: + print(e) + raise IOError("Process not created") if ret != expected_return_val: raise IOError(f"Process returned {ret} (expected {expected_return_val})") @@ -64,6 +68,7 @@ def run_all(self) -> str: bat_file += "exit /B 0\r\n" + comspec = os.getenv("COMSPEC", "cmd.exe") with temp_bat_file(bat_file) as f: print( f"Executing bat script as admin. Saved as {f}. Check for an admin prompt. " @@ -71,7 +76,7 @@ def run_all(self) -> str: ) sleep(1) # Wait for file handle to be closed etc try: - AdminRunner.run_command("cmd", f"/c {f}", expected_return_val=0) + AdminRunner.run_command(f"{comspec}", f"/c {f}", expected_return_val=0) except IOError as e: print(f"Error while executing bat script: {e}.") with open(log_file.name, "r") as logfile: