From 8a9720ce8191f00668d67bbf9f15bf4ede5b28c4 Mon Sep 17 00:00:00 2001 From: Jonathan Karlsen Date: Tue, 24 Sep 2024 14:13:45 +0200 Subject: [PATCH] Have job_dispatch.py safely terminate child processes on exception --- src/_ert/forward_model_runner/job_dispatch.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/_ert/forward_model_runner/job_dispatch.py b/src/_ert/forward_model_runner/job_dispatch.py index 7af3b6e4bc0..ccd1e5044c2 100644 --- a/src/_ert/forward_model_runner/job_dispatch.py +++ b/src/_ert/forward_model_runner/job_dispatch.py @@ -13,7 +13,12 @@ def sigterm_handler(_signo, _stack_frame): def main(): os.nice(19) signal.signal(signal.SIGTERM, sigterm_handler) - job_runner_main(sys.argv) + try: + job_runner_main(sys.argv) + except Exception as e: + pgid = os.getpgid(os.getpid()) + os.killpg(pgid, signal.SIGTERM) + raise e if __name__ == "__main__":