Commit 23490a23 authored by Claude Paroz's avatar Claude Paroz
Browse files

Revert "Fixed 19895 -- Made second iteration over invalid queryset raise an exception too"

This reverts commit 2cd0edaa.
This commit was the cause of a memory leak. See ticket for more details.
Thanks Anssi Kääriäinen for identifying the source of the bug.
parent ccb87f97
Loading
Loading
Loading
Loading
+1 −13
Original line number Diff line number Diff line
@@ -104,7 +104,7 @@ class QuerySet(object):
            len(self)

        if self._result_cache is None:
            self._iter = self._safe_iterator(self.iterator())
            self._iter = self.iterator()
            self._result_cache = []
        if self._iter:
            return self._result_iter()
@@ -341,18 +341,6 @@ class QuerySet(object):

            yield obj

    def _safe_iterator(self, iterator):
        # ensure result cache is cleared when iterating over a queryset
        # raises an exception
        try:
            for item in iterator:
                yield item
        except StopIteration:
            raise
        except Exception:
            self._result_cache = None
            raise

    def aggregate(self, *args, **kwargs):
        """
        Returns a dictionary containing the calculations (aggregation)
+1 −6
Original line number Diff line number Diff line
@@ -3,7 +3,7 @@ from __future__ import absolute_import, unicode_literals
from datetime import datetime
import threading

from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned, FieldError
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned
from django.db import connections, DEFAULT_DB_ALIAS
from django.db.models.fields import Field, FieldDoesNotExist
from django.db.models.query import QuerySet, EmptyQuerySet, ValuesListQuerySet
@@ -689,11 +689,6 @@ class ModelTest(TestCase):
        with self.assertNumQueries(0):
            self.assertEqual(len(Article.objects.none().distinct('headline', 'pub_date')), 0)

    def test_invalid_qs_list(self):
        qs = Article.objects.order_by('invalid_column')
        self.assertRaises(FieldError, list, qs)
        self.assertRaises(FieldError, list, qs)

class ConcurrentSaveTests(TransactionTestCase):
    @skipUnlessDBFeature('test_db_allows_multiple_connections')
    def test_concurrent_delete_with_save(self):