Fixed #10399 -- Tested that o2o field updates are not constrained by an inner query.

This commit is contained in:
Simon Charette 2013-03-01 15:32:39 -05:00
parent 952ba5237e
commit fb3d85bd14
1 changed files with 25 additions and 1 deletions

View File

@ -1,9 +1,11 @@
from __future__ import absolute_import from __future__ import absolute_import, unicode_literals
from operator import attrgetter from operator import attrgetter
from django.core.exceptions import FieldError from django.core.exceptions import FieldError
from django.db import connection
from django.test import TestCase from django.test import TestCase
from django.test.testcases import CaptureQueriesContext
from django.utils import six from django.utils import six
from .models import (Chef, CommonInfo, ItalianRestaurant, ParkingLot, Place, from .models import (Chef, CommonInfo, ItalianRestaurant, ParkingLot, Place,
@ -294,3 +296,25 @@ class ModelInheritanceTests(TestCase):
) )
with self.assertNumQueries(6): with self.assertNumQueries(6):
ir.save() ir.save()
def test_update_parent_filtering(self):
"""
Test that updating a field of a model subclass doesn't issue an UPDATE
query constrained by an inner query.
Refs #10399
"""
supplier = Supplier.objects.create(
name='Central market',
address='610 some street'
)
# Capture the expected query in a database agnostic way
with CaptureQueriesContext(connection) as captured_queries:
Place.objects.filter(pk=supplier.pk).update(name=supplier.name)
expected_sql = captured_queries[0]['sql']
# Capture the queries executed when a subclassed model instance is saved.
with CaptureQueriesContext(connection) as captured_queries:
supplier.save(update_fields=('name',))
for query in captured_queries:
sql = query['sql']
if 'UPDATE' in sql:
self.assertEqual(expected_sql, sql)