Skip to content

Commit

Permalink
fixed same bug for nested List inside MapField, little code refactori…
Browse files Browse the repository at this point in the history
…ng, added test for nested list and nested reference fields
  • Loading branch information
elephanter committed Apr 30, 2015
1 parent 31f7769 commit ebaba95
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 3 deletions.
4 changes: 1 addition & 3 deletions mongoengine/dereference.py
Original file line number Diff line number Diff line change
Expand Up @@ -219,11 +219,9 @@ def _attach_objects(self, items, depth=0, instance=None, name=None):
data[k]._data[field_name] = self.object_map.get(v.id, v)
elif isinstance(v, (dict, SON)) and '_ref' in v:
data[k]._data[field_name] = self.object_map.get(v['_ref'].id, v)
elif isinstance(v, dict) and depth <= self.max_depth:
elif isinstance(v, (dict, list, tuple)) and depth <= self.max_depth:
item_name = "{0}.{1}.{2}".format(name, k, field_name)
data[k]._data[field_name] = self._attach_objects(v, depth, instance=instance, name=item_name)
elif isinstance(v, (list, tuple)) and depth <= self.max_depth:
data[k]._data[field_name] = self._attach_objects(v, depth, instance=instance, name=name)
elif isinstance(v, (dict, list, tuple)) and depth <= self.max_depth:
item_name = '%s.%s' % (name, k) if name else name
data[k] = self._attach_objects(v, depth - 1, instance=instance, name=item_name)
Expand Down
15 changes: 15 additions & 0 deletions tests/document/delta.py
Original file line number Diff line number Diff line change
Expand Up @@ -828,12 +828,17 @@ class User(Document):
self.assertEqual(org2.name, 'New Org 2')

def test_delta_for_nested_map_fields(self):
class UInfoDocument(Document):
phone = StringField()

class EmbeddedRole(EmbeddedDocument):
type = StringField()

class EmbeddedUser(EmbeddedDocument):
name = StringField()
roles = MapField(field=EmbeddedDocumentField(EmbeddedRole))
rolist = ListField(field=EmbeddedDocumentField(EmbeddedRole))
info = ReferenceField(UInfoDocument)

class Doc(Document):
users = MapField(field=EmbeddedDocumentField(EmbeddedUser))
Expand All @@ -845,11 +850,21 @@ class Doc(Document):
doc.users["007"] = EmbeddedUser(name="Agent007")
doc.save()

uinfo = UInfoDocument(phone="79089269066")
uinfo.save()

d = Doc.objects(num=1).first()
d.users["007"]["roles"]["666"] = EmbeddedRole(type="superadmin")
d.users["007"]["rolist"].append(EmbeddedRole(type="oops"))
d.users["007"]["info"] = uinfo
delta = d._delta()
print delta
self.assertEqual(True, "users.007.roles.666" in delta[0])
self.assertEqual(True, "users.007.rolist" in delta[0])
self.assertEqual(True, "users.007.info" in delta[0])
self.assertEqual('superadmin', delta[0]["users.007.roles.666"]["type"])
self.assertEqual('oops', delta[0]["users.007.rolist"][0]["type"])
self.assertEqual(uinfo.id, delta[0]["users.007.info"])

if __name__ == '__main__':
unittest.main()

0 comments on commit ebaba95

Please sign in to comment.