diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-12-06 22:00:35 -0500 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2011-12-06 22:00:35 -0500 |
| commit | c718ad227efe4b389c09f167a375c57969cf4bb4 (patch) | |
| tree | 3dcab43480d0ba1d811e5e965b91290100c5dfdb /test/sql/test_defaults.py | |
| parent | 7ebcd26f741ea6e3c8bfc470529626f547a04ba8 (diff) | |
| download | sqlalchemy-c718ad227efe4b389c09f167a375c57969cf4bb4.tar.gz | |
tests for FK/autoincrement selection
Diffstat (limited to 'test/sql/test_defaults.py')
| -rw-r--r-- | test/sql/test_defaults.py | 24 |
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) |
