From 0e7b2fc33bacb78a9259ebb71c07e00f5bdc2269 Mon Sep 17 00:00:00 2001 From: Jake Fennick Date: Wed, 8 May 2024 16:07:57 -1000 Subject: [PATCH] python api use subprocess.run() --- src/wic/api/pythonapi.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/wic/api/pythonapi.py b/src/wic/api/pythonapi.py index e2056e20..9c0d9f69 100644 --- a/src/wic/api/pythonapi.py +++ b/src/wic/api/pythonapi.py @@ -585,6 +585,7 @@ def write_ast_to_disk(self, directory: Path) -> None: yaml_contents = {"inputs": inputs, "steps": steps} if inputs else {"steps": steps} # NOTE: For various reasons, process_name should be globally unique. # In this case, it is to avoid overwriting files. + directory.mkdir(exist_ok=True, parents=True) with open(str(directory / self.process_name) + '.wic', mode='w', encoding='utf-8') as f: f.write(yaml.dump(yaml_contents, sort_keys=False, line_break='\n', indent=2)) @@ -755,7 +756,7 @@ def run(self) -> None: input_output.write_to_disk(rose_tree, Path('autogenerated/'), relative_run_path=True) # Do NOT capture stdout and/or stderr and pipe warnings and errors into a black hole. - retval = run_local_module.run_local(args, rose_tree, args.cachedir, 'cwltool', False) + retval = run_local_module.run_local(args, rose_tree, args.cachedir, 'cwltool', True) # Finally, since there is an output file copying bug in cwltool, # we need to copy the output files manually. See comment above.