From 906d5448439bfbb9add1e5e37a6811ad065d054f Mon Sep 17 00:00:00 2001 From: Ben Clifford Date: Thu, 11 Apr 2024 12:32:17 -0500 Subject: [PATCH] Add more cases for std stream logging (#3347) Previously, stdout/err logs not output if the streams were not set (i.e. defaulting to None) and logged with the entire stream target if set. This PR adds more cases here with case specific logging: if stdout/err is not redirected, that is now logged. If tuple mode is used, the tuple is unpacked and logged as separate fields. If an unknown format is specified an error is logged (but no exception is raised - it is not the job of this code to validate the stdout/err specifications) This PR is in preparation for a new case to be added in an upcoming PR which requires more serious formatting that was not accomodated by the previous implementation. --- parsl/dataflow/dflow.py | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/parsl/dataflow/dflow.py b/parsl/dataflow/dflow.py index 70027cf01c..7253d1efea 100644 --- a/parsl/dataflow/dflow.py +++ b/parsl/dataflow/dflow.py @@ -1391,10 +1391,20 @@ def load_checkpoints(self, checkpointDirs: Optional[Sequence[str]]) -> Dict[str, @staticmethod def _log_std_streams(task_record: TaskRecord) -> None: - if task_record['app_fu'].stdout is not None: - logger.info("Standard output for task {} available at {}".format(task_record['id'], task_record['app_fu'].stdout)) - if task_record['app_fu'].stderr is not None: - logger.info("Standard error for task {} available at {}".format(task_record['id'], task_record['app_fu'].stderr)) + tid = task_record['id'] + + def log_std_stream(name: str, target) -> None: + if target is None: + logger.info(f"{name} for task {tid} will not be redirected.") + elif isinstance(target, str): + logger.info(f"{name} for task {tid} will be redirected to {target}") + elif isinstance(target, tuple) and len(target) == 2: + logger.info(f"{name} for task {tid} will be redirected to {target[0]} with mode {target[1]}") + else: + logger.error(f"{name} for task {tid} has unknown specification: {target!r}") + + log_std_stream("Standard out", task_record['app_fu'].stdout) + log_std_stream("Standard error", task_record['app_fu'].stderr) class DataFlowKernelLoader: