From 5a9d0263addcd53897cc15b2c1ad952353640a2c Mon Sep 17 00:00:00 2001 From: Nick Crews Date: Mon, 1 Jul 2024 07:08:05 -0800 Subject: [PATCH] fix(polars): add workaround to compile Array correctly (#9484) Workaround for https://github.com/pola-rs/polars/issues/17294 pl.concat_list(Iterable[T]) results in pl.List[T], EXCEPT when T is a pl.List, in which case pl.concat_list(Iterable[pl.List[T]]) results in pl.List[T]. If polars ever supports a more consistent array constructor, we should switch to that. Found this when working on https://github.com/ibis-project/ibis/pull/9473 --- ibis/backends/polars/compiler.py | 7 +++++++ ibis/backends/tests/test_array.py | 9 +-------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/ibis/backends/polars/compiler.py b/ibis/backends/polars/compiler.py index 4d9a497191b4..4cdfd8714dfe 100644 --- a/ibis/backends/polars/compiler.py +++ b/ibis/backends/polars/compiler.py @@ -976,6 +976,13 @@ def array_concat(op, **kw): @translate.register(ops.Array) def array_column(op, **kw): cols = [translate(col, **kw) for col in op.exprs] + # Workaround for https://github.com/pola-rs/polars/issues/17294 + # pl.concat_list(Iterable[T]) results in pl.List[T], EXCEPT when T is a + # pl.List, in which case pl.concat_list(Iterable[pl.List[T]]) results in pl.List[T]. + # If polars ever supports a more consistent array constructor, + # we should switch to that. + if op.dtype.value_type.is_array(): + cols = [c.implode() for c in cols] return pl.concat_list(cols) diff --git a/ibis/backends/tests/test_array.py b/ibis/backends/tests/test_array.py index 1d3633a0e4ea..7e024c59c4b1 100644 --- a/ibis/backends/tests/test_array.py +++ b/ibis/backends/tests/test_array.py @@ -1352,14 +1352,7 @@ def test_unnest_range(con): [[1], ibis.literal([2])], [[1], [2]], id="array", - marks=[ - pytest.mark.notyet(["bigquery"], raises=GoogleBadRequest), - pytest.mark.broken( - ["polars"], - reason="expression input not supported with nested arrays", - raises=TypeError, - ), - ], + marks=[pytest.mark.notyet(["bigquery"], raises=GoogleBadRequest)], ), ], )