summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/sqlalchemy/schema.py23
-rw-r--r--test/engine/test_metadata.py27
2 files changed, 48 insertions, 2 deletions
diff --git a/lib/sqlalchemy/schema.py b/lib/sqlalchemy/schema.py
index e61f17d8e..fc5dd33df 100644
--- a/lib/sqlalchemy/schema.py
+++ b/lib/sqlalchemy/schema.py
@@ -478,7 +478,28 @@ class Table(SchemaItem, expression.TableClause):
args.append(c.copy(schema=schema))
for c in self.constraints:
args.append(c.copy(schema=schema))
- return Table(self.name, metadata, schema=schema, *args, **self.kwargs)
+ table = Table(
+ self.name, metadata, schema=schema,
+ *args, **self.kwargs
+ )
+ copied_already = set()
+ for i in table.indexes:
+ entry = [i.name,i.unique]
+ entry.extend(sorted(i.kwargs.items()))
+ entry.extend(i.columns.keys())
+ copied_already.add(tuple(entry))
+ for i in self.indexes:
+ cols = i.columns.keys()
+ entry = [i.name,i.unique]
+ entry.extend(sorted(i.kwargs.items()))
+ entry.extend(cols)
+ if tuple(entry) not in copied_already:
+ kwargs = dict(i.kwargs)
+ kwargs['unique']=i.unique
+ Index(i.name,
+ *[getattr(table.c,col) for col in cols],
+ **kwargs)
+ return table
class Column(SchemaItem, expression.ColumnClause):
"""Represents a column in a database table."""
diff --git a/test/engine/test_metadata.py b/test/engine/test_metadata.py
index 5c6f5c151..a99188f15 100644
--- a/test/engine/test_metadata.py
+++ b/test/engine/test_metadata.py
@@ -2,7 +2,7 @@ from sqlalchemy.test.testing import assert_raises, assert_raises_message
import pickle
from sqlalchemy import Integer, String, UniqueConstraint, \
CheckConstraint, ForeignKey, MetaData, Sequence, \
- ForeignKeyConstraint, ColumnDefault
+ ForeignKeyConstraint, ColumnDefault, Index
from sqlalchemy.test.schema import Table, Column
from sqlalchemy import schema, exc
import sqlalchemy as tsa
@@ -259,6 +259,31 @@ class MetaDataTest(TestBase, ComparesTables):
eq_(table.kwargs,table_c.kwargs)
+ def test_tometadata_indexes(self):
+ meta = MetaData()
+
+ table = Table('mytable', meta,
+ Column('id', Integer, primary_key=True),
+ Column('data1', Integer, index=True),
+ Column('data2', Integer),
+ )
+ Index('multi',table.c.data1,table.c.data2),
+
+ meta2 = MetaData()
+ table_c = table.tometadata(meta2)
+
+ def _get_key(i):
+ entry = [i.name,i.unique]
+ entry.extend(sorted(i.kwargs.items()))
+ entry.extend(i.columns.keys())
+
+ table_indexes = [_get_key(i) for i in table.indexes]
+ table_indexes.sort()
+ table_c_indexes = [_get_key(i) for i in table_c.indexes]
+ table_c_indexes.sort()
+
+ eq_(table_indexes,table_c_indexes)
+
def test_tometadata_default_schema(self):
meta = MetaData()