From 8221314d3c569a39f2ccddfd3770fbb7643eea1f Mon Sep 17 00:00:00 2001 From: Gerda Shank Date: Tue, 1 Oct 2024 14:55:49 -0400 Subject: [PATCH 1/3] Add is_list jinja filter --- dbt_common/clients/jinja.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/dbt_common/clients/jinja.py b/dbt_common/clients/jinja.py index d27c264..2cee922 100644 --- a/dbt_common/clients/jinja.py +++ b/dbt_common/clients/jinja.py @@ -470,11 +470,16 @@ def __reduce__(self) -> NoReturn: return Undefined +def is_list(value): + return isinstance(value, list) + + NATIVE_FILTERS: Dict[str, Callable[[Any], Any]] = { "as_text": TextMarker, "as_bool": BoolMarker, "as_native": NativeMarker, "as_number": NumberMarker, + "is_list": is_list, } @@ -483,6 +488,7 @@ def __reduce__(self) -> NoReturn: "as_bool": lambda x: x, "as_native": lambda x: x, "as_number": lambda x: x, + "is_list": is_list, } From 1a643e3132c8ca9bed753052debc8e2d37863170 Mon Sep 17 00:00:00 2001 From: Gerda Shank Date: Tue, 1 Oct 2024 16:17:41 -0400 Subject: [PATCH 2/3] Changie --- .changes/unreleased/Under the Hood-20241001-161733.yaml | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100644 .changes/unreleased/Under the Hood-20241001-161733.yaml diff --git a/.changes/unreleased/Under the Hood-20241001-161733.yaml b/.changes/unreleased/Under the Hood-20241001-161733.yaml new file mode 100644 index 0000000..9ef3baa --- /dev/null +++ b/.changes/unreleased/Under the Hood-20241001-161733.yaml @@ -0,0 +1,6 @@ +kind: Under the Hood +body: Add a jinja "is_list" filter +time: 2024-10-01T16:17:33.652809-04:00 +custom: + Author: gshank + Issue: "200" From 8aa646b68766fa5f12f52ef88668581e002226b8 Mon Sep 17 00:00:00 2001 From: Gerda Shank Date: Tue, 1 Oct 2024 16:43:24 -0400 Subject: [PATCH 3/3] Add test --- tests/unit/test_jinja.py | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/tests/unit/test_jinja.py b/tests/unit/test_jinja.py index cf44eee..e839296 100644 --- a/tests/unit/test_jinja.py +++ b/tests/unit/test_jinja.py @@ -1,7 +1,7 @@ import unittest from dbt_common.clients._jinja_blocks import BlockTag -from dbt_common.clients.jinja import extract_toplevel_blocks +from dbt_common.clients.jinja import extract_toplevel_blocks, get_template, render_template from dbt_common.exceptions import CompilationError @@ -503,3 +503,24 @@ def test_if_endfor_newlines(self) -> None: hi {% endmaterialization %} """ + + +def test_if_list_filter(): + jinja_string = """ + {%- if my_var | is_list -%} + Found a list + {%- else -%} + Did not find a list + {%- endif -%} + """ + # Check with list variable + ctx = {"my_var": ["one", "two"]} + template = get_template(jinja_string, ctx) + rendered = render_template(template, ctx) + assert "Found a list" in rendered + + # Check with non-list variable + ctx = {"my_var": "one"} + template = get_template(jinja_string, ctx) + rendered = render_template(template, ctx) + assert "Did not find a list" in rendered