summaryrefslogtreecommitdiff
path: root/test/sql/test_compiler.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2012-06-21 16:49:29 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2012-06-21 16:49:29 -0400
commitd5186e92534b4d38e590cef2d56c85be845bfdf0 (patch)
tree45e774615f0f35a761a8711cddb145545f364e06 /test/sql/test_compiler.py
parentd5609d77841ab4e607e6b372a15396b38ddace9a (diff)
downloadsqlalchemy-d5186e92534b4d38e590cef2d56c85be845bfdf0.tar.gz
- [bug] quoting is applied to the column names
inside the WITH RECURSIVE clause of a common table expression according to the quoting rules for the originating Column. [ticket:2512]
Diffstat (limited to 'test/sql/test_compiler.py')
-rw-r--r--test/sql/test_compiler.py14
1 files changed, 14 insertions, 0 deletions
diff --git a/test/sql/test_compiler.py b/test/sql/test_compiler.py
index 4bf0eb70e..22353f142 100644
--- a/test/sql/test_compiler.py
+++ b/test/sql/test_compiler.py
@@ -2486,6 +2486,20 @@ class SelectTest(fixtures.TestBase, AssertsCompiledSQL):
"FROM regional_sales WHERE "
"regional_sales.amount < :amount_2")
+ def test_cte_reserved_quote(self):
+ orders = table('orders',
+ column('order'),
+ )
+ s = select([orders.c.order]).cte("regional_sales", recursive=True)
+ s = select([s.c.order])
+ self.assert_compile(s,
+ 'WITH RECURSIVE regional_sales("order") AS '
+ '(SELECT orders."order" AS "order" '
+ "FROM orders)"
+ ' SELECT regional_sales."order" '
+ "FROM regional_sales"
+ )
+
def test_date_between(self):
import datetime
table = Table('dt', metadata,