diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-04-24 13:49:09 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2015-04-24 13:49:09 -0400 |
| commit | e73f735382371ac5c05a46f2a51fd10971270fe4 (patch) | |
| tree | d2cf84d2223e103bfde643da755e4e7487c791de /test/ext | |
| parent | 0fc751e4abea999b5cc7ba8c3a87a7a84cd5aa8c (diff) | |
| download | sqlalchemy-e73f735382371ac5c05a46f2a51fd10971270fe4.tar.gz | |
- Fixed regression regarding the declarative ``__declare_first__``
and ``__declare_last__`` accessors where these would no longer be
called on the superclass of the declarative base.
fixes #3383
Diffstat (limited to 'test/ext')
| -rw-r--r-- | test/ext/declarative/test_inheritance.py | 3 | ||||
| -rw-r--r-- | test/ext/declarative/test_mixin.py | 87 |
2 files changed, 88 insertions, 2 deletions
diff --git a/test/ext/declarative/test_inheritance.py b/test/ext/declarative/test_inheritance.py index 2ecee99fd..3e6980190 100644 --- a/test/ext/declarative/test_inheritance.py +++ b/test/ext/declarative/test_inheritance.py @@ -1451,4 +1451,5 @@ class ConcreteExtensionConfigTest( "actual_documents.send_method AS send_method, " "actual_documents.id AS id, 'actual' AS type " "FROM actual_documents) AS pjoin" - )
\ No newline at end of file + ) + diff --git a/test/ext/declarative/test_mixin.py b/test/ext/declarative/test_mixin.py index 45b881671..b9e40421c 100644 --- a/test/ext/declarative/test_mixin.py +++ b/test/ext/declarative/test_mixin.py @@ -9,7 +9,8 @@ from sqlalchemy.orm import relationship, create_session, class_mapper, \ configure_mappers, clear_mappers, \ deferred, column_property, Session, base as orm_base from sqlalchemy.util import classproperty -from sqlalchemy.ext.declarative import declared_attr +from sqlalchemy.ext.declarative import declared_attr, declarative_base +from sqlalchemy.orm import events as orm_events from sqlalchemy.testing import fixtures, mock from sqlalchemy.testing.util import gc_collect @@ -438,6 +439,90 @@ class DeclarativeMixinTest(DeclarativeTestBase): eq_(MyModel.__table__.kwargs, {'mysql_engine': 'InnoDB'}) + @testing.teardown_events(orm_events.MapperEvents) + def test_declare_first_mixin(self): + canary = mock.Mock() + + class MyMixin(object): + @classmethod + def __declare_first__(cls): + canary.declare_first__(cls) + + @classmethod + def __declare_last__(cls): + canary.declare_last__(cls) + + class MyModel(Base, MyMixin): + __tablename__ = 'test' + id = Column(Integer, primary_key=True) + + configure_mappers() + + eq_( + canary.mock_calls, + [ + mock.call.declare_first__(MyModel), + mock.call.declare_last__(MyModel), + ] + ) + + @testing.teardown_events(orm_events.MapperEvents) + def test_declare_first_base(self): + canary = mock.Mock() + + class MyMixin(object): + @classmethod + def __declare_first__(cls): + canary.declare_first__(cls) + + @classmethod + def __declare_last__(cls): + canary.declare_last__(cls) + + class Base(MyMixin): + pass + Base = declarative_base(cls=Base) + + class MyModel(Base): + __tablename__ = 'test' + id = Column(Integer, primary_key=True) + + configure_mappers() + + eq_( + canary.mock_calls, + [ + mock.call.declare_first__(MyModel), + mock.call.declare_last__(MyModel), + ] + ) + + @testing.teardown_events(orm_events.MapperEvents) + def test_declare_first_direct(self): + canary = mock.Mock() + + class MyOtherModel(Base): + __tablename__ = 'test2' + id = Column(Integer, primary_key=True) + + @classmethod + def __declare_first__(cls): + canary.declare_first__(cls) + + @classmethod + def __declare_last__(cls): + canary.declare_last__(cls) + + configure_mappers() + + eq_( + canary.mock_calls, + [ + mock.call.declare_first__(MyOtherModel), + mock.call.declare_last__(MyOtherModel) + ] + ) + def test_mapper_args_declared_attr(self): class ComputedMapperArgs: |
