summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Gaynor <alex.gaynor@gmail.com>2010-06-22 18:09:08 +0000
committerAlex Gaynor <alex.gaynor@gmail.com>2010-06-22 18:09:08 +0000
commitd6993c7dbb4ffef939e9061a701be2e442971d3b (patch)
treef6977576979d24e98860840242358e66434aa781
parent33523c9f95d47dec1a06ef2515af269e91be19b5 (diff)
[soc2010/query-refactor] Fixed Querysets in MongoDB with a limit of 0.
git-svn-id: http://code.djangoproject.com/svn/django/branches/soc2010/query-refactor@13382 bcc190cf-cafb-0310-a4f2-bffc1f526a37
-rw-r--r--django/contrib/mongodb/compiler.py9
-rw-r--r--tests/regressiontests/mongodb/tests.py3
2 files changed, 8 insertions, 4 deletions
diff --git a/django/contrib/mongodb/compiler.py b/django/contrib/mongodb/compiler.py
index 880f9bc7cd..3a1a14fd14 100644
--- a/django/contrib/mongodb/compiler.py
+++ b/django/contrib/mongodb/compiler.py
@@ -1,6 +1,6 @@
from pymongo import ASCENDING, DESCENDING
-from django.db.models.sql.datastructures import FullResultSet
+from django.db.models.sql.datastructures import FullResultSet, EmptyResultSet
# TODO: ...
@@ -87,11 +87,16 @@ class SQLCompiler(object):
if self.query.low_mark:
cursor = cursor.skip(self.query.low_mark)
if self.query.high_mark is not None:
+ if self.query.high_mark - self.query.low_mark == 0:
+ raise EmptyResultSet
cursor = cursor.limit(self.query.high_mark - self.query.low_mark)
return cursor
def results_iter(self):
- query = self.build_query()
+ try:
+ query = self.build_query()
+ except EmptyResultSet:
+ return
fields = self.get_fields(aggregates=False)
if fields is None:
fields = [
diff --git a/tests/regressiontests/mongodb/tests.py b/tests/regressiontests/mongodb/tests.py
index 5c58f81171..e977ebeb42 100644
--- a/tests/regressiontests/mongodb/tests.py
+++ b/tests/regressiontests/mongodb/tests.py
@@ -95,8 +95,7 @@ class MongoTestCase(TestCase):
]
for i in xrange(5):
- # TODO: should be i, but Mongo falls over with limit(0)
- for j in xrange(i+1, 5):
+ for j in xrange(i, 5):
self.assertQuerysetEqual(
Artist.objects.all()[i:j],
artists[i:j],