Fixed #32704 -- Fixed list of deferred fields when chaining QuerySet.defer() after only().
This commit is contained in:
parent
96706d76cd
commit
fd999318ad
|
@ -2086,7 +2086,12 @@ class Query(BaseExpression):
|
||||||
self.deferred_loading = existing.union(field_names), True
|
self.deferred_loading = existing.union(field_names), True
|
||||||
else:
|
else:
|
||||||
# Remove names from the set of any existing "immediate load" names.
|
# Remove names from the set of any existing "immediate load" names.
|
||||||
self.deferred_loading = existing.difference(field_names), False
|
if new_existing := existing.difference(field_names):
|
||||||
|
self.deferred_loading = new_existing, False
|
||||||
|
else:
|
||||||
|
self.clear_deferred_loading()
|
||||||
|
if new_only := set(field_names).difference(existing):
|
||||||
|
self.deferred_loading = new_only, True
|
||||||
|
|
||||||
def add_immediate_loading(self, field_names):
|
def add_immediate_loading(self, field_names):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -52,6 +52,8 @@ class DeferTests(AssertionMixin, TestCase):
|
||||||
self.assert_delayed(qs.defer('name').only('name').only('value')[0], 2)
|
self.assert_delayed(qs.defer('name').only('name').only('value')[0], 2)
|
||||||
self.assert_delayed(qs.defer("name").only("value")[0], 2)
|
self.assert_delayed(qs.defer("name").only("value")[0], 2)
|
||||||
self.assert_delayed(qs.only("name").defer("value")[0], 2)
|
self.assert_delayed(qs.only("name").defer("value")[0], 2)
|
||||||
|
self.assert_delayed(qs.only('name').defer('name').defer('value')[0], 1)
|
||||||
|
self.assert_delayed(qs.only('name').defer('name', 'value')[0], 1)
|
||||||
|
|
||||||
def test_defer_only_clear(self):
|
def test_defer_only_clear(self):
|
||||||
qs = Primary.objects.all()
|
qs = Primary.objects.all()
|
||||||
|
|
Loading…
Reference in New Issue