From 01feeb1ee08c4af7c1ba3ef62f00e9b5fff08e59 Mon Sep 17 00:00:00 2001 From: Goran Jelic-Cizmek Date: Tue, 29 Oct 2024 16:54:04 +0100 Subject: [PATCH] Better assertion in util --- .../python/neuron/tests/utils/checkresult.py | 23 ++++++++----------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/share/lib/python/neuron/tests/utils/checkresult.py b/share/lib/python/neuron/tests/utils/checkresult.py index 4a39f434a7..bbb991413a 100644 --- a/share/lib/python/neuron/tests/utils/checkresult.py +++ b/share/lib/python/neuron/tests/utils/checkresult.py @@ -1,5 +1,7 @@ import json import math +import os + from neuron import h, hoc @@ -17,7 +19,6 @@ def __init__(self, fname, must_exist=True): A temporary must_exist=False provides a simple way for the test author to bootstrap the file. """ - import os self.fname = fname self.d = {} @@ -48,33 +49,29 @@ def equal(a, b): assert type(a) == type(b) if type(a) in (float, int): match = math.isclose(a, b, rel_tol=tol) - if not match: - print(a, b, "diff", abs(a - b) / max(abs(a), abs(b)), ">", tol) + assert ( + match + ), f"{a}, {b}, diff = {abs(a - b) / max(abs(a), abs(b))} > {tol}" return match elif type(a) == str: match = a == b - if not match: - print("strdiff", a, b) + assert match, f"strdiff: {a} != {b}" return match elif type(a) == list: # List comprehension avoids short-circuit, so the "diff" # message just above is printed for all elements - return all([equal(aa, bb) for aa, bb in zip(a, b)]) + return all(equal(aa, bb) for aa, bb in zip(a, b)) elif type(a) == dict: assert a.keys() == b.keys() - return all([equal(a[k], b[k]) for k in a.keys()]) + return all(equal(a[k], b[k]) for k in a.keys()) raise Exception( "Don't know how to compare objects of type " + str(type(a)) ) match = equal(value, self.d[key]) - if not match: - print(key, "difference") - print("std = ", self.d[key]) - print("val = ", value) - assert match + assert match, f"{key=}, difference:\nstd = {self.d[key]}\n{value=}" else: - print("{} added {}".format(self, key)) + print(f"{self} added {key}") if isinstance(value, hoc.Vector): self.d[key] = value.to_python() else: