Mongomallard
This commit is contained in:
parent
ede9fcfb00
commit
dcc5d3c858
24 changed files with 584 additions and 1102 deletions
|
|
@ -390,24 +390,27 @@ class InstanceTest(unittest.TestCase):
|
|||
doc.embedded_field = embedded_1
|
||||
doc.save()
|
||||
|
||||
doc = doc.reload(10)
|
||||
doc = doc.reload()
|
||||
doc.list_field.append(1)
|
||||
doc.dict_field['woot'] = "woot"
|
||||
doc.embedded_field.list_field.append(1)
|
||||
doc.embedded_field.dict_field['woot'] = "woot"
|
||||
|
||||
self.assertEqual(doc._get_changed_fields(), [
|
||||
'list_field', 'dict_field', 'embedded_field.list_field',
|
||||
'embedded_field.dict_field'])
|
||||
self.assertEqual(doc._get_changed_fields(), set([
|
||||
'list_field', 'dict_field', 'embedded_field']))
|
||||
#self.assertEqual(doc._get_changed_fields(), [
|
||||
# 'list_field', 'dict_field', 'embedded_field.list_field',
|
||||
# 'embedded_field.dict_field'])
|
||||
doc.save()
|
||||
|
||||
doc = doc.reload(10)
|
||||
self.assertEqual(doc._get_changed_fields(), [])
|
||||
doc = doc.reload()
|
||||
self.assertEqual(doc._get_changed_fields(), set())
|
||||
self.assertEqual(len(doc.list_field), 4)
|
||||
self.assertEqual(len(doc.dict_field), 2)
|
||||
self.assertEqual(len(doc.embedded_field.list_field), 4)
|
||||
self.assertEqual(len(doc.embedded_field.dict_field), 2)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_dictionary_access(self):
|
||||
"""Ensure that dictionary-style field access works properly.
|
||||
"""
|
||||
|
|
@ -438,10 +441,10 @@ class InstanceTest(unittest.TestCase):
|
|||
class Employee(Person):
|
||||
salary = IntField()
|
||||
|
||||
self.assertEqual(Person(name="Bob", age=35).to_mongo().keys(),
|
||||
['_cls', 'name', 'age'])
|
||||
self.assertEqual(Employee(name="Bob", age=35, salary=0).to_mongo().keys(),
|
||||
['_cls', 'name', 'age', 'salary'])
|
||||
self.assertEqual(set(Person(name="Bob", age=35).to_mongo().keys()),
|
||||
set(['_cls', 'name', 'age']))
|
||||
self.assertEqual(set(Employee(name="Bob", age=35, salary=0).to_mongo().keys()),
|
||||
set(['_cls', 'name', 'age', 'salary']))
|
||||
|
||||
def test_embedded_document(self):
|
||||
"""Ensure that embedded documents are set up correctly.
|
||||
|
|
@ -452,6 +455,7 @@ class InstanceTest(unittest.TestCase):
|
|||
self.assertTrue('content' in Comment._fields)
|
||||
self.assertFalse('id' in Comment._fields)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_embedded_document_instance(self):
|
||||
"""Ensure that embedded documents can reference parent instance
|
||||
"""
|
||||
|
|
@ -460,6 +464,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
class Doc(Document):
|
||||
embedded_field = EmbeddedDocumentField(Embedded)
|
||||
meta = { 'cascade': True }
|
||||
|
||||
Doc.drop_collection()
|
||||
Doc(embedded_field=Embedded(string="Hi")).save()
|
||||
|
|
@ -467,6 +472,7 @@ class InstanceTest(unittest.TestCase):
|
|||
doc = Doc.objects.get()
|
||||
self.assertEqual(doc, doc.embedded_field._instance)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_embedded_document_complex_instance(self):
|
||||
"""Ensure that embedded documents in complex fields can reference
|
||||
parent instance"""
|
||||
|
|
@ -623,6 +629,7 @@ class InstanceTest(unittest.TestCase):
|
|||
p0.name = 'wpjunior'
|
||||
p0.save()
|
||||
|
||||
@unittest.skip("FileField not implemented")
|
||||
def test_save_max_recursion_not_hit_with_file_field(self):
|
||||
|
||||
class Foo(Document):
|
||||
|
|
@ -771,6 +778,7 @@ class InstanceTest(unittest.TestCase):
|
|||
p1.reload()
|
||||
self.assertEqual(p1.name, p.parent.name)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_update(self):
|
||||
"""Ensure that an existing document is updated instead of be
|
||||
overwritten."""
|
||||
|
|
@ -885,7 +893,6 @@ class InstanceTest(unittest.TestCase):
|
|||
reference_field = ReferenceField(Simple, default=lambda:
|
||||
Simple().save())
|
||||
map_field = MapField(IntField(), default=lambda: {"simple": 1})
|
||||
decimal_field = DecimalField(default=1.0)
|
||||
complex_datetime_field = ComplexDateTimeField(default=datetime.now)
|
||||
url_field = URLField(default="http://mongoengine.org")
|
||||
dynamic_field = DynamicField(default=1)
|
||||
|
|
@ -1054,9 +1061,9 @@ class InstanceTest(unittest.TestCase):
|
|||
user = User.objects.first()
|
||||
# Even if stored as ObjectId's internally mongoengine uses DBRefs
|
||||
# As ObjectId's aren't automatically derefenced
|
||||
self.assertTrue(isinstance(user._data['orgs'][0], DBRef))
|
||||
#self.assertTrue(isinstance(user._data['orgs'][0], DBRef))
|
||||
self.assertTrue(isinstance(user.orgs[0], Organization))
|
||||
self.assertTrue(isinstance(user._data['orgs'][0], Organization))
|
||||
#self.assertTrue(isinstance(user._data['orgs'][0], Organization))
|
||||
|
||||
# Changing a value
|
||||
with query_counter() as q:
|
||||
|
|
@ -1136,6 +1143,7 @@ class InstanceTest(unittest.TestCase):
|
|||
foo.save()
|
||||
self.assertEqual(1, q)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_save_only_changed_fields_recursive(self):
|
||||
"""Ensure save only sets / unsets changed fields
|
||||
"""
|
||||
|
|
@ -1433,8 +1441,8 @@ class InstanceTest(unittest.TestCase):
|
|||
post_obj = BlogPost.objects.first()
|
||||
|
||||
# Test laziness
|
||||
self.assertTrue(isinstance(post_obj._data['author'],
|
||||
bson.DBRef))
|
||||
#self.assertTrue(isinstance(post_obj._data['author'],
|
||||
# bson.DBRef))
|
||||
self.assertTrue(isinstance(post_obj.author, self.Person))
|
||||
self.assertEqual(post_obj.author.name, 'Test User')
|
||||
|
||||
|
|
@ -1458,6 +1466,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertRaises(InvalidDocumentError, throw_invalid_document_error)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_invalid_son(self):
|
||||
"""Raise an error if loading invalid data"""
|
||||
class Occurrence(EmbeddedDocument):
|
||||
|
|
@ -1801,6 +1810,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertTrue(u1 in all_user_set)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_picklable(self):
|
||||
|
||||
pickle_doc = PickleTest(number=1, string="One", lists=['1', '2'])
|
||||
|
|
@ -1827,6 +1837,7 @@ class InstanceTest(unittest.TestCase):
|
|||
self.assertEqual(pickle_doc.string, "Two")
|
||||
self.assertEqual(pickle_doc.lists, ["1", "2", "3"])
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_picklable_on_signals(self):
|
||||
pickle_doc = PickleSignalsTest(number=1, string="One", lists=['1', '2'])
|
||||
pickle_doc.embedded = PickleEmbedded()
|
||||
|
|
@ -1887,6 +1898,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertEqual(Doc.objects(archived=False).count(), 1)
|
||||
|
||||
@unittest.skip("DynamicDocument not implemented")
|
||||
def test_can_save_false_values_dynamic(self):
|
||||
"""Ensures you can save False values on dynamic docs"""
|
||||
class Doc(DynamicDocument):
|
||||
|
|
@ -2026,6 +2038,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertEqual('testdb-1', B._meta.get('db_alias'))
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_db_ref_usage(self):
|
||||
""" DB Ref usage in dict_fields"""
|
||||
|
||||
|
|
@ -2104,6 +2117,7 @@ class InstanceTest(unittest.TestCase):
|
|||
})]),
|
||||
"1,2")
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_switch_db_instance(self):
|
||||
register_connection('testdb-1', 'mongoenginetest2')
|
||||
|
||||
|
|
@ -2175,9 +2189,10 @@ class InstanceTest(unittest.TestCase):
|
|||
user = User.objects.first()
|
||||
self.assertEqual("Ross", user.username)
|
||||
self.assertEqual(True, user.foo)
|
||||
self.assertEqual("Bar", user._data["foo"])
|
||||
self.assertEqual([1, 2, 3], user._data["data"])
|
||||
self.assertEqual("Bar", user._db_data["foo"])
|
||||
self.assertEqual([1, 2, 3], user._db_data["data"])
|
||||
|
||||
@unittest.skip("DynamicDocument not implemented")
|
||||
def test_spaces_in_keys(self):
|
||||
|
||||
class Embedded(DynamicEmbeddedDocument):
|
||||
|
|
@ -2194,6 +2209,7 @@ class InstanceTest(unittest.TestCase):
|
|||
one = Doc.objects.filter(**{'hello world': 1}).count()
|
||||
self.assertEqual(1, one)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_shard_key(self):
|
||||
class LogEntry(Document):
|
||||
machine = StringField()
|
||||
|
|
@ -2217,6 +2233,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertRaises(OperationError, change_shard_key)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_shard_key_primary(self):
|
||||
class LogEntry(Document):
|
||||
machine = StringField(primary_key=True)
|
||||
|
|
@ -2240,6 +2257,7 @@ class InstanceTest(unittest.TestCase):
|
|||
|
||||
self.assertRaises(OperationError, change_shard_key)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_kwargs_simple(self):
|
||||
|
||||
class Embedded(EmbeddedDocument):
|
||||
|
|
@ -2254,8 +2272,9 @@ class InstanceTest(unittest.TestCase):
|
|||
"doc": {"name": "embedded doc"}})
|
||||
|
||||
self.assertEqual(classic_doc, dict_doc)
|
||||
self.assertEqual(classic_doc._data, dict_doc._data)
|
||||
self.assertEqual(classic_doc.to_dict(), dict_doc.to_dict())
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_kwargs_complex(self):
|
||||
|
||||
class Embedded(EmbeddedDocument):
|
||||
|
|
@ -2273,8 +2292,9 @@ class InstanceTest(unittest.TestCase):
|
|||
{"name": "embedded doc2"}]})
|
||||
|
||||
self.assertEqual(classic_doc, dict_doc)
|
||||
self.assertEqual(classic_doc._data, dict_doc._data)
|
||||
self.assertEqual(classic_doc.to_dict(), dict_doc.to_dict())
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_positional_creation(self):
|
||||
"""Ensure that document may be created using positional arguments.
|
||||
"""
|
||||
|
|
@ -2282,6 +2302,7 @@ class InstanceTest(unittest.TestCase):
|
|||
self.assertEqual(person.name, "Test User")
|
||||
self.assertEqual(person.age, 42)
|
||||
|
||||
@unittest.skip("not implemented")
|
||||
def test_mixed_creation(self):
|
||||
"""Ensure that document may be created using mixed arguments.
|
||||
"""
|
||||
|
|
@ -2307,8 +2328,8 @@ class InstanceTest(unittest.TestCase):
|
|||
Person(name="Harry Potter").save()
|
||||
|
||||
person = Person.objects.first()
|
||||
self.assertTrue('id' in person._data.keys())
|
||||
self.assertEqual(person._data.get('id'), person.id)
|
||||
self.assertTrue('id' in person.to_dict().keys())
|
||||
self.assertEqual(person.to_dict().get('id'), person.id)
|
||||
|
||||
def test_complex_nesting_document_and_embedded_document(self):
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue