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
|
||||
else:
|
||||
# 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):
|
||||
"""
|
||||
|
|
|
@ -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("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):
|
||||
qs = Primary.objects.all()
|
||||
|
|
Loading…
Reference in New Issue