summaryrefslogtreecommitdiff
path: root/test/sql/test_defaults.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2011-12-06 22:00:35 -0500
committerMike Bayer <mike_mp@zzzcomputing.com>2011-12-06 22:00:35 -0500
commitc718ad227efe4b389c09f167a375c57969cf4bb4 (patch)
tree3dcab43480d0ba1d811e5e965b91290100c5dfdb /test/sql/test_defaults.py
parent7ebcd26f741ea6e3c8bfc470529626f547a04ba8 (diff)
downloadsqlalchemy-c718ad227efe4b389c09f167a375c57969cf4bb4.tar.gz
tests for FK/autoincrement selection
Diffstat (limited to 'test/sql/test_defaults.py')
-rw-r--r--test/sql/test_defaults.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/test/sql/test_defaults.py b/test/sql/test_defaults.py
index 334a9d97c..c0d3c2d49 100644
--- a/test/sql/test_defaults.py
+++ b/test/sql/test_defaults.py
@@ -552,6 +552,30 @@ class AutoIncrementTest(fixtures.TablesTest):
)
assert t._autoincrement_column is None
+ def test_autoincrement_ignore_fk(self):
+ m = MetaData()
+ y = Table('y', m,
+ Column('id', Integer(), primary_key=True)
+ )
+ x = Table('x', m,
+ Column('id', Integer(),
+ ForeignKey('y.id'),
+ autoincrement="ignore_fk", primary_key=True)
+ )
+ assert x._autoincrement_column is x.c.id
+
+ def test_autoincrement_fk_disqualifies(self):
+ m = MetaData()
+ y = Table('y', m,
+ Column('id', Integer(), primary_key=True)
+ )
+ x = Table('x', m,
+ Column('id', Integer(),
+ ForeignKey('y.id'),
+ primary_key=True)
+ )
+ assert x._autoincrement_column is None
+
@testing.fails_on('sqlite', 'FIXME: unknown')
def test_non_autoincrement(self):
# sqlite INT primary keys can be non-unique! (only for ints)