Compare commits
4 Commits
master
...
queryset-c
Author | SHA1 | Date | |
---|---|---|---|
|
38c36c0ba4 | ||
|
c1a8b468c5 | ||
|
890e58bfcd | ||
|
debc28a5cf |
@ -933,6 +933,14 @@ class BaseQuerySet(object):
|
|||||||
queryset._ordering = queryset._get_order_by(keys)
|
queryset._ordering = queryset._get_order_by(keys)
|
||||||
return queryset
|
return queryset
|
||||||
|
|
||||||
|
def comment(self, text):
|
||||||
|
"""Add a comment to the query.
|
||||||
|
|
||||||
|
See https://docs.mongodb.com/manual/reference/method/cursor.comment/#cursor.comment
|
||||||
|
for details.
|
||||||
|
"""
|
||||||
|
return self._chainable_method("comment", text)
|
||||||
|
|
||||||
def explain(self, format=False):
|
def explain(self, format=False):
|
||||||
"""Return an explain plan record for the
|
"""Return an explain plan record for the
|
||||||
:class:`~mongoengine.queryset.QuerySet`\ 's cursor.
|
:class:`~mongoengine.queryset.QuerySet`\ 's cursor.
|
||||||
|
@ -339,7 +339,6 @@ class QuerySetTest(unittest.TestCase):
|
|||||||
|
|
||||||
def test_update_write_concern(self):
|
def test_update_write_concern(self):
|
||||||
"""Test that passing write_concern works"""
|
"""Test that passing write_concern works"""
|
||||||
|
|
||||||
self.Person.drop_collection()
|
self.Person.drop_collection()
|
||||||
|
|
||||||
write_concern = {"fsync": True}
|
write_concern = {"fsync": True}
|
||||||
@ -2199,6 +2198,21 @@ class QuerySetTest(unittest.TestCase):
|
|||||||
a.author.name for a in Author.objects.order_by('-author__age')]
|
a.author.name for a in Author.objects.order_by('-author__age')]
|
||||||
self.assertEqual(names, ['User A', 'User B', 'User C'])
|
self.assertEqual(names, ['User A', 'User B', 'User C'])
|
||||||
|
|
||||||
|
def test_comment(self):
|
||||||
|
"""Make sure adding a comment to the query works."""
|
||||||
|
class User(Document):
|
||||||
|
age = IntField()
|
||||||
|
|
||||||
|
with db_ops_tracker() as q:
|
||||||
|
adult = (User.objects.filter(age__gte=18)
|
||||||
|
.comment('looking for an adult')
|
||||||
|
.first())
|
||||||
|
ops = q.get_ops()
|
||||||
|
self.assertEqual(len(ops), 1)
|
||||||
|
op = ops[0]
|
||||||
|
self.assertEqual(op['query']['$query'], {'age': {'$gte': 18}})
|
||||||
|
self.assertEqual(op['query']['$comment'], 'looking for an adult')
|
||||||
|
|
||||||
def test_map_reduce(self):
|
def test_map_reduce(self):
|
||||||
"""Ensure map/reduce is both mapping and reducing.
|
"""Ensure map/reduce is both mapping and reducing.
|
||||||
"""
|
"""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user