aboutsummaryrefslogtreecommitdiffstats
path: root/tests/hazmat/backends
diff options
context:
space:
mode:
Diffstat (limited to 'tests/hazmat/backends')
-rw-r--r--tests/hazmat/backends/test_openssl_memleak.py22
1 files changed, 13 insertions, 9 deletions
diff --git a/tests/hazmat/backends/test_openssl_memleak.py b/tests/hazmat/backends/test_openssl_memleak.py
index e4cbd0fb..53c41375 100644
--- a/tests/hazmat/backends/test_openssl_memleak.py
+++ b/tests/hazmat/backends/test_openssl_memleak.py
@@ -102,15 +102,19 @@ def assert_no_memory_leaks(s, argv=[]):
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
)
- proc.wait()
- if proc.returncode == 255:
- # 255 means there was a leak, load the info about what mallocs weren't
- # freed.
- out = json.loads(proc.stdout.read().decode())
- raise AssertionError(out)
- elif proc.returncode != 0:
- # Any exception type will do to be honest
- raise ValueError(proc.stdout.read(), proc.stderr.read())
+ try:
+ proc.wait()
+ if proc.returncode == 255:
+ # 255 means there was a leak, load the info about what mallocs
+ # weren't freed.
+ out = json.loads(proc.stdout.read().decode())
+ raise AssertionError(out)
+ elif proc.returncode != 0:
+ # Any exception type will do to be honest
+ raise ValueError(proc.stdout.read(), proc.stderr.read())
+ finally:
+ proc.stdout.close()
+ proc.stderr.close()
def skip_if_memtesting_not_supported():