summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2014-06-26 14:58:42 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2014-06-26 14:58:42 -0400
commitf2cf62090c4f9812bf4a57a9f68172b1b2eafd6c (patch)
treed307939815e99897d034a09cdc2dbea5d607bc2a
parentfeda84e5b2c4e3dd313a5fce7c4e5c0cdfd9851e (diff)
downloadsqlalchemy-f2cf62090c4f9812bf4a57a9f68172b1b2eafd6c.tar.gz
- Fixed bug involving dynamic attributes, that was again a regression
of :ticket:`3060` from verision 0.9.5. A self-referential relationship with lazy='dynamic' would raise a TypeError within a flush operation. fixes #3099
-rw-r--r--doc/build/changelog/changelog_09.rst8
-rw-r--r--lib/sqlalchemy/orm/dynamic.py5
-rw-r--r--test/orm/test_dynamic.py17
3 files changed, 28 insertions, 2 deletions
diff --git a/doc/build/changelog/changelog_09.rst b/doc/build/changelog/changelog_09.rst
index 3c7772b28..56d43a9e6 100644
--- a/doc/build/changelog/changelog_09.rst
+++ b/doc/build/changelog/changelog_09.rst
@@ -15,6 +15,14 @@
:released:
.. change::
+ :tags: bug, orm
+ :tickets: 3099
+
+ Fixed bug involving dynamic attributes, that was again a regression
+ of :ticket:`3060` from verision 0.9.5. A self-referential relationship
+ with lazy='dynamic' would raise a TypeError within a flush operation.
+
+ .. change::
:tags: bug, declarative
:tickets: 3097
:versions: 1.0.0
diff --git a/lib/sqlalchemy/orm/dynamic.py b/lib/sqlalchemy/orm/dynamic.py
index bae09d32d..82e0b0048 100644
--- a/lib/sqlalchemy/orm/dynamic.py
+++ b/lib/sqlalchemy/orm/dynamic.py
@@ -171,9 +171,10 @@ class DynamicAttributeImpl(attributes.AttributeImpl):
c = self._get_collection_history(state, passive)
return c.as_history()
- def get_all_pending(self, state, dict_):
+ def get_all_pending(self, state, dict_,
+ passive=attributes.PASSIVE_NO_INITIALIZE):
c = self._get_collection_history(
- state, attributes.PASSIVE_NO_INITIALIZE)
+ state, passive)
return [
(attributes.instance_state(x), x)
for x in
diff --git a/test/orm/test_dynamic.py b/test/orm/test_dynamic.py
index 21dcfd436..54ea3c2f1 100644
--- a/test/orm/test_dynamic.py
+++ b/test/orm/test_dynamic.py
@@ -600,6 +600,23 @@ class UOWTest(_DynamicFixture, _fixtures.FixtureTest,
def test_delete_cascade(self):
self._test_delete_cascade(False)
+ def test_self_referential(self):
+ Node, nodes = self.classes.Node, self.tables.nodes
+
+
+ mapper(Node, nodes, properties={
+ 'children': relationship(Node, lazy="dynamic", order_by=nodes.c.id)
+ })
+
+ sess = Session()
+ n2, n3 = Node(), Node()
+ n1 = Node(children=[n2, n3])
+ sess.add(n1)
+ sess.commit()
+
+ eq_(n1.children.all(), [n2, n3])
+
+
def test_remove_orphans(self):
addresses = self.tables.addresses
User, Address = self._user_address_fixture(addresses_args={