- this partially fixes some issues in [ticket:1022] but leaving the "unlabeled" fix for 0.5 for now
col, intersect = None, None
target_set = column.proxy_set
- for c in self.c + [self.oid_column]:
+ cols = self.c
+ if self.oid_column:
+ cols += [self.oid_column]
+ for c in cols:
i = c.proxy_set.intersection(target_set)
if i and \
(not require_embedded or c.proxy_set.issuperset(target_set)) and \
def _make_proxy(self, selectable, name = None):
if isinstance(self.obj, (Selectable, ColumnElement)):
- return self.obj._make_proxy(selectable, name=self.name)
+ e = self.obj._make_proxy(selectable, name=self.name)
else:
- return column(self.name)._make_proxy(selectable=selectable)
+ e = column(self.name)._make_proxy(selectable=selectable)
+ e.proxies.append(self)
+ return e
class _ColumnClause(ColumnElement):
"""Represents a generic column expression from any textual string.
self.assertEquals(user.query_score, user.prop_score)
self.assert_sql_count(testing.db, go, 1)
- u = session.query(User).filter_by(name='joe').one()
- self.assertEquals(u.query_score, u.prop_score)
-
- # fails:
- #def go():
- # u = session.query(User).filter_by(name='joe').one()
- # self.assertEquals(u.query_score, u.prop_score)
- #self.assert_sql_count(testing.db, go, 1)
+
+ # fails for non labeled (fixed in 0.5):
+ if labeled:
+ def go():
+ u = session.query(User).filter_by(name='joe').one()
+ self.assertEquals(u.query_score, u.prop_score)
+ self.assert_sql_count(testing.db, go, 1)
+ else:
+ u = session.query(User).filter_by(name='joe').one()
+ self.assertEquals(u.query_score, u.prop_score)
for t in (tags_table, users_table):
t.delete().execute()
print str(j)
self.assert_(criterion.compare(j.onclause))
+ def test_labeled_select_correspoinding(self):
+ l1 = select([func.max(table.c.col1)]).label('foo')
+
+ s = select([l1])
+ assert s.corresponding_column(l1).name == s.c.foo
+
+ s = select([table.c.col1, l1])
+ assert s.corresponding_column(l1).name == s.c.foo
+
def testselectaliaslabels(self):
a = table2.select(use_labels=True).alias('a')
print str(a.select())