mirror of
https://github.com/sqlalchemy/sqlalchemy.git
synced 2026-05-17 22:22:13 -04:00
- fixed very stupid bug when deleting items with many-to-many
uselist=False relations
This commit is contained in:
@@ -8,6 +8,8 @@
|
||||
- association proxies no longer bind tightly to source collections
|
||||
[ticket:597], and are constructed with a thunk instead
|
||||
- orm
|
||||
- fixed very stupid bug when deleting items with many-to-many
|
||||
uselist=False relations
|
||||
- remember all that stuff about polymorphic_union ? for
|
||||
joined table inheritance ? Funny thing...
|
||||
You sort of don't need it for joined table inheritance, you
|
||||
|
||||
@@ -338,7 +338,7 @@ class ManyToManyDP(DependencyProcessor):
|
||||
childlist = self.get_object_dependencies(obj, uowcommit, passive=self.passive_deletes)
|
||||
if childlist is not None:
|
||||
for child in childlist.deleted_items() + childlist.unchanged_items():
|
||||
if reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes:
|
||||
if child is None or (reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes):
|
||||
continue
|
||||
associationrow = {}
|
||||
self._synchronize(obj, child, associationrow, False, uowcommit)
|
||||
@@ -349,14 +349,14 @@ class ManyToManyDP(DependencyProcessor):
|
||||
childlist = self.get_object_dependencies(obj, uowcommit)
|
||||
if childlist is None: continue
|
||||
for child in childlist.added_items():
|
||||
if reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes:
|
||||
if child is None or (reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes):
|
||||
continue
|
||||
associationrow = {}
|
||||
self._synchronize(obj, child, associationrow, False, uowcommit)
|
||||
uowcommit.attributes[(self, "manytomany", obj, child)] = True
|
||||
secondary_insert.append(associationrow)
|
||||
for child in childlist.deleted_items():
|
||||
if reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes:
|
||||
if child is None or (reverse_dep and (reverse_dep, "manytomany", child, obj) in uowcommit.attributes):
|
||||
continue
|
||||
associationrow = {}
|
||||
self._synchronize(obj, child, associationrow, False, uowcommit)
|
||||
|
||||
@@ -1277,6 +1277,21 @@ class ManyToManyTest(UnitOfWorkTest):
|
||||
ctx.current.flush()
|
||||
assert itemkeywords.count().scalar() == 0
|
||||
|
||||
def testscalar(self):
|
||||
"""test that dependency.py doesnt try to delete an m2m relation referencing None."""
|
||||
|
||||
mapper(Keyword, keywords)
|
||||
|
||||
mapper(Item, orderitems, properties = dict(
|
||||
keyword = relation(Keyword, secondary=itemkeywords, uselist=False),
|
||||
))
|
||||
|
||||
i = Item()
|
||||
ctx.current.flush()
|
||||
ctx.current.delete(i)
|
||||
ctx.current.flush()
|
||||
|
||||
|
||||
|
||||
def testmanytomanyupdate(self):
|
||||
"""tests some history operations on a many to many"""
|
||||
|
||||
Reference in New Issue
Block a user