From f4e102c406fa30f11bb4dce2e7307cedb46bb220 Mon Sep 17 00:00:00 2001 From: Aaron Berger Date: Fri, 28 Jun 2024 12:35:12 +0200 Subject: [PATCH 1/3] easified code for subprocess execution --- autoverify/verifier/verifier.py | 38 +++++++-------------------------- 1 file changed, 8 insertions(+), 30 deletions(-) diff --git a/autoverify/verifier/verifier.py b/autoverify/verifier/verifier.py index b38dbe6..7a98b51 100644 --- a/autoverify/verifier/verifier.py +++ b/autoverify/verifier/verifier.py @@ -313,44 +313,24 @@ def _run_verification( for context in contexts: stack.enter_context(context) - process = subprocess.Popen( - run_cmd, - executable="/bin/bash", + before_t = time.time() + + process = subprocess.run( + run_cmd, + executable="/bin/bash", stdout=subprocess.PIPE, stderr=subprocess.STDOUT, shell=True, universal_newlines=True, - preexec_fn=os.setsid, - ) - - before_t = time.time() - self._timeout_event: threading.Event | None = threading.Event() - - def _terminate(timeout_sec): - assert self._timeout_event - on_time = self._timeout_event.wait(timeout_sec) - - if not on_time: - global result - result = "TIMEOUT" # type: ignore - - if pid_exists(process.pid): - os.killpg(os.getpgid(process.pid), signal.SIGTERM) - - t = threading.Thread(target=_terminate, args=[timeout]) - t.start() + preexec_fn=os.setsid) assert process.stdout - for line in iter(process.stdout.readline, ""): - output_lines.append(line) + output_str = process.stdout - process.stdout.close() - return_code = process.wait() + return_code = process.returncode took_t = time.time() - before_t - self._timeout_event.set() - output_str = "".join(output_lines) counter_example: str | None = None if result != "TIMEOUT": @@ -361,8 +341,6 @@ def _terminate(timeout_sec): output_str, result_file ) - self._timeout_event = None - return CompleteVerificationData( result, # type: ignore took_t, From d3e35563a8b9e675b9452c2056be6853fc49dd2c Mon Sep 17 00:00:00 2001 From: Aaron Berger Date: Fri, 28 Jun 2024 12:35:40 +0200 Subject: [PATCH 2/3] removed killing of processes with the verifier name in it --- autoverify/verifier/complete/abcrown/verifier.py | 1 - autoverify/verifier/complete/nnenum/verifier.py | 3 +-- autoverify/verifier/complete/ovalbab/verifier.py | 1 - 3 files changed, 1 insertion(+), 4 deletions(-) diff --git a/autoverify/verifier/complete/abcrown/verifier.py b/autoverify/verifier/complete/abcrown/verifier.py index 5040919..3680b75 100644 --- a/autoverify/verifier/complete/abcrown/verifier.py +++ b/autoverify/verifier/complete/abcrown/verifier.py @@ -48,7 +48,6 @@ def contexts(self) -> list[ContextManager[None]]: # Ideally just keep track of PIDs rather than pkill name matching return [ cwd(self.tool_path / "complete_verifier"), - pkill_matches(["python abcrown.py"]), ] def _parse_result( diff --git a/autoverify/verifier/complete/nnenum/verifier.py b/autoverify/verifier/complete/nnenum/verifier.py index c31c2af..e08297a 100644 --- a/autoverify/verifier/complete/nnenum/verifier.py +++ b/autoverify/verifier/complete/nnenum/verifier.py @@ -46,7 +46,6 @@ def contexts(self) -> list[ContextManager[None]]: return [ cwd(self.tool_path / "src"), environment(OPENBLAS_NUM_THREADS="1", OMP_NUM_THREADS="1"), - pkill_matches(["python -m nnenum.nnenum"]), ] def _parse_result( @@ -97,7 +96,7 @@ def _get_run_cmd( conda activate {self.conda_env_name} python -m nnenum.nnenum {str(network)} {str(property)} {str(timeout)} \ {str(result_file)} \ - {str(cpu_count())} \ + {6} \ {settings_str} \ {shlex.quote(str(config))} \ """ diff --git a/autoverify/verifier/complete/ovalbab/verifier.py b/autoverify/verifier/complete/ovalbab/verifier.py index 624e47c..ff76d69 100644 --- a/autoverify/verifier/complete/ovalbab/verifier.py +++ b/autoverify/verifier/complete/ovalbab/verifier.py @@ -52,7 +52,6 @@ def contexts(self) -> list[ContextManager[None]]: find_conda_lib(self.conda_env_name, "libcudart.so.11.0") ) ), - pkill_matches(["python tools/bab_tools/bab_from_vnnlib.py"]), ] def _parse_result( From ff7964fad100f5275e6fc128734294c25806788b Mon Sep 17 00:00:00 2001 From: Aaron Berger Date: Fri, 28 Jun 2024 12:39:41 +0200 Subject: [PATCH 3/3] added back cpu count method --- autoverify/verifier/complete/nnenum/verifier.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/autoverify/verifier/complete/nnenum/verifier.py b/autoverify/verifier/complete/nnenum/verifier.py index e08297a..d87ff54 100644 --- a/autoverify/verifier/complete/nnenum/verifier.py +++ b/autoverify/verifier/complete/nnenum/verifier.py @@ -96,7 +96,7 @@ def _get_run_cmd( conda activate {self.conda_env_name} python -m nnenum.nnenum {str(network)} {str(property)} {str(timeout)} \ {str(result_file)} \ - {6} \ + {str(cpu_count())} \ {settings_str} \ {shlex.quote(str(config))} \ """