summaryrefslogtreecommitdiff
path: root/test/sql
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2022-12-19 15:15:35 -0500
committerMike Bayer <mike_mp@zzzcomputing.com>2022-12-20 10:56:21 -0500
commit567878e5c67d08c561dd064fe6dc25e4db7349e7 (patch)
treedd0e50cbf7105758c0ea5931606c15f6e079c0b6 /test/sql
parent946058ec6070ab4db9fdfab612ec4543fea9cd1c (diff)
downloadsqlalchemy-567878e5c67d08c561dd064fe6dc25e4db7349e7.tar.gz
add joins_implicitly to column_valued()
Added parameter :paramref:`.FunctionElement.column_valued.joins_implicitly`, which is useful in preventing the "cartesian product" warning when making use of table-valued or column-valued functions. This parameter was already introduced for :meth:`.FunctionElement.table_valued` in :ticket:`7845`, however it failed to be added for :meth:`.FunctionElement.column_valued` as well. Fixes: #9009 Change-Id: Ifb72fbcb4f4d2998e730d6f85ec7280df3bf3d47
Diffstat (limited to 'test/sql')
-rw-r--r--test/sql/test_from_linter.py54
1 files changed, 37 insertions, 17 deletions
diff --git a/test/sql/test_from_linter.py b/test/sql/test_from_linter.py
index 1fa3aff36..49370b1e6 100644
--- a/test/sql/test_from_linter.py
+++ b/test/sql/test_from_linter.py
@@ -165,16 +165,16 @@ class TestFindUnmatchingFroms(fixtures.TablesTest):
assert start is p3
assert froms == {p1}
- @testing.combinations(
- "render_derived", "alias", None, argnames="additional_transformation"
+ @testing.variation("additional_transformation", ["alias", "none"])
+ @testing.variation("joins_implicitly", [True, False])
+ @testing.variation(
+ "type_", ["table_valued", "table_valued_derived", "column_valued"]
)
- @testing.combinations(True, False, argnames="joins_implicitly")
- def test_table_valued(
- self,
- joins_implicitly,
- additional_transformation,
+ def test_fn_valued(
+ self, joins_implicitly, additional_transformation, type_
):
- """test #7845"""
+ """test #7845, #9009"""
+
my_table = table(
"tbl",
column("id", Integer),
@@ -183,25 +183,45 @@ class TestFindUnmatchingFroms(fixtures.TablesTest):
sub_dict = my_table.c.data["d"]
- tv = func.json_each(sub_dict)
+ if type_.table_valued or type_.table_valued_derived:
+ tv = func.json_each(sub_dict)
+
+ tv = tv.table_valued("key", joins_implicitly=joins_implicitly)
+
+ if type_.table_valued_derived:
+ tv = tv.render_derived(name="tv", with_types=True)
+
+ if additional_transformation.alias:
+ tv = tv.alias()
+
+ has_key = tv.c.key == "f"
+ stmt = select(my_table.c.id).where(has_key)
+ elif type_.column_valued:
+ tv = func.json_array_elements(sub_dict)
- tv = tv.table_valued("key", joins_implicitly=joins_implicitly)
+ if additional_transformation.alias:
+ tv = tv.alias(joins_implicitly=joins_implicitly).column
+ else:
+ tv = tv.column_valued("key", joins_implicitly=joins_implicitly)
- if additional_transformation == "render_derived":
- tv = tv.render_derived(name="tv", with_types=True)
- elif additional_transformation == "alias":
- tv = tv.alias()
+ stmt = select(my_table.c.id, tv)
+ else:
+ type_.fail()
- has_key = tv.c.key == "f"
- stmt = select(my_table.c.id).where(has_key)
froms, start = find_unmatching_froms(stmt, my_table)
if joins_implicitly:
is_(start, None)
is_(froms, None)
- else:
+ elif type_.column_valued:
+ assert start == my_table
+ assert froms == {tv.scalar_alias}
+
+ elif type_.table_valued or type_.table_valued_derived:
assert start == my_table
assert froms == {tv}
+ else:
+ type_.fail()
def test_count_non_eq_comparison_operators(self):
query = select(self.a).where(self.a.c.col_a > self.b.c.col_b)