From 6f1a5732411ca911afe1f8a1c71f99d8719ab177 Mon Sep 17 00:00:00 2001 From: Partho Sarthi Date: Fri, 27 Oct 2023 14:00:38 -0700 Subject: [PATCH] Fix system command processing during logging in user tools (#633) * Fix incorrect splitting of system cmd having string type Signed-off-by: Partho Sarthi * Fix subscriptable type Signed-off-by: Partho Sarthi * Concise if-else condition Signed-off-by: Partho Sarthi --------- Signed-off-by: Partho Sarthi --- user_tools/src/spark_rapids_pytools/cloud_api/sp_types.py | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/user_tools/src/spark_rapids_pytools/cloud_api/sp_types.py b/user_tools/src/spark_rapids_pytools/cloud_api/sp_types.py index b8f4f6a29..2ea9e4864 100644 --- a/user_tools/src/spark_rapids_pytools/cloud_api/sp_types.py +++ b/user_tools/src/spark_rapids_pytools/cloud_api/sp_types.py @@ -20,7 +20,7 @@ from dataclasses import dataclass, field from enum import Enum from logging import Logger -from typing import Type, Any, List, Callable +from typing import Type, Any, List, Callable, Union from spark_rapids_tools import EnumeratedType, CspEnv from spark_rapids_pytools.common.prop_manager import AbstractPropertiesContainer, JSONPropertiesContainer, \ @@ -369,7 +369,7 @@ def validate_env(self): self._handle_inconsistent_configurations(incorrect_envs) def run_sys_cmd(self, - cmd, + cmd: Union[str, list], cmd_input: str = None, fail_ok: bool = False, env_vars: dict = None) -> str: @@ -393,7 +393,9 @@ def process_streams(std_out, std_err): if len(stdout_splits) > 0: std_out_lines = Utils.gen_multiline_str([f'\t| {line}' for line in stdout_splits]) stdout_str = f'\n\t\n{std_out_lines}' - cmd_log_str = Utils.gen_joined_str(' ', process_credentials_option(cmd)) + # if the command is already a list, use it as-is. Otherwise, split the string into a list. + cmd_list = cmd if isinstance(cmd, list) else cmd.split(' ') + cmd_log_str = Utils.gen_joined_str(' ', process_credentials_option(cmd_list)) if len(stderr_splits) > 0: std_err_lines = Utils.gen_multiline_str([f'\t| {line}' for line in stderr_splits]) stderr_str = f'\n\t\n{std_err_lines}'