(core) Don't swallow TypeErrors in functions like SUM

Summary: Math functions like SUM which call `_chain` were catching `TypeError`s raised by the iterable arguments themselves, e.g. `SUM(r.A / r.B for r in $group)` where `r.A / r.B` raises a `TypeError` would silently return wrong results. This diff narrows the `try/catch` to only check whether the argument is iterable as intended, but not catch errors from the process of iterating.

Test Plan: Added Python unit test.

Reviewers: jarek

Reviewed By: jarek

Differential Revision: https://phab.getgrist.com/D3679
This commit is contained in:
Alex Hall 2022-10-24 21:12:27 +02:00
parent caef8bae22
commit aa88c156e6
2 changed files with 10 additions and 2 deletions

View File

@ -21,10 +21,12 @@ import roman
def _chain(*values_or_iterables): def _chain(*values_or_iterables):
for v in values_or_iterables: for v in values_or_iterables:
try: try:
for x in v: v = iter(v)
yield x
except TypeError: except TypeError:
yield v yield v
else:
for x in v:
yield x
# Iterates through iterable or other arguments, skipping non-numeric ones. # Iterates through iterable or other arguments, skipping non-numeric ones.

View File

@ -80,3 +80,9 @@ class TestUuid(unittest.TestCase):
self.check_uuids(1) # because of the `random.seed(0)` in `check_uuids()` self.check_uuids(1) # because of the `random.seed(0)` in `check_uuids()`
finally: finally:
uuid.uuid4 = v4 uuid.uuid4 = v4
class TestChain(unittest.TestCase):
def test_chain_type_error(self):
with self.assertRaises(TypeError):
functions.SUM(x / "2" for x in [1, 2, 3])