.. changelog::
:version: 1.1.0b1
+ .. change::
+ :tags: bug, sql
+ :tickets: 3616
+
+ Fixed an assertion that would raise somewhat inappropriately
+ if a :class:`.Index` were associated with a :class:`.Column` that
+ is associated with a lower-case-t :class:`.TableClause`; the
+ association should be ignored for the purposes of associating
+ the index with a :class:`.Table`.
+
.. change::
:tags: bug, orm
:tickets: 3601
has_string_cols = set(self._pending_colargs).difference(col_objs)
if not has_string_cols:
def _col_attached(column, table):
- cols_wo_table.discard(column)
- if not cols_wo_table:
- self._check_attach(evt=True)
+ # this isinstance() corresponds with the
+ # isinstance() above; only want to count Table-bound
+ # columns
+ if isinstance(table, Table):
+ cols_wo_table.discard(column)
+ if not cols_wo_table:
+ self._check_attach(evt=True)
self._cols_wo_table = cols_wo_table
for col in cols_wo_table:
col._on_table_attach(_col_attached)
t.append_constraint, idx
)
+ def test_column_associated_w_lowercase_table(self):
+ from sqlalchemy import table
+ c = Column('x', Integer)
+ table('foo', c)
+ idx = Index('q', c)
+ is_(idx.table, None) # lower-case-T table doesn't have indexes
+
class ConstraintTest(fixtures.TestBase):