summaryrefslogtreecommitdiff
path: root/test/ext
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2015-04-24 13:49:09 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2015-04-24 13:49:09 -0400
commite73f735382371ac5c05a46f2a51fd10971270fe4 (patch)
treed2cf84d2223e103bfde643da755e4e7487c791de /test/ext
parent0fc751e4abea999b5cc7ba8c3a87a7a84cd5aa8c (diff)
downloadsqlalchemy-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.py3
-rw-r--r--test/ext/declarative/test_mixin.py87
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: