summaryrefslogtreecommitdiff
path: root/test/sql/test_roles.py
diff options
context:
space:
mode:
Diffstat (limited to 'test/sql/test_roles.py')
-rw-r--r--test/sql/test_roles.py20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/sql/test_roles.py b/test/sql/test_roles.py
index 4d905aca9..d5e8f476c 100644
--- a/test/sql/test_roles.py
+++ b/test/sql/test_roles.py
@@ -175,6 +175,26 @@ class RoleTest(fixtures.TestBase):
select(column("q")).alias(),
)
+ def test_table_valued_advice(self):
+ msg = (
+ r"SQL expression element expected, got %s. To create a "
+ r"column expression from a FROM clause row as a whole, "
+ r"use the .table_valued\(\) method."
+ )
+ assert_raises_message(
+ exc.ArgumentError,
+ msg % ("Table.*",),
+ expect,
+ roles.ExpressionElementRole,
+ t,
+ )
+
+ # no table_valued() message here right now, it goes to scalar subquery
+ with testing.expect_warnings(
+ "implicitly coercing SELECT object to scalar subquery"
+ ):
+ expect(roles.ExpressionElementRole, t.select().alias())
+
def test_statement_no_text_coercion(self):
assert_raises_message(
exc.ArgumentError,