Fixed #28856 -- Fixed a regression in caching of a GenericForeignKey pointing to a MTI model.

Regression in b9f8635f58.
This commit is contained in:
Simon Charette 2017-11-29 01:06:45 -05:00 committed by Tim Graham
parent f0a68c2511
commit e50add6ca1
6 changed files with 23 additions and 11 deletions

View File

@ -872,6 +872,9 @@ class ForeignKey(ForeignObject):
kwargs['to_field'] = self.remote_field.field_name kwargs['to_field'] = self.remote_field.field_name
return name, path, args, kwargs return name, path, args, kwargs
def to_python(self, value):
return self.target_field.to_python(value)
@property @property
def target_field(self): def target_field(self):
return self.foreign_related_fields[0] return self.foreign_related_fields[0]

View File

@ -27,3 +27,6 @@ Bugfixes
* Made query lookups for ``CICharField``, ``CIEmailField``, and ``CITextField`` * Made query lookups for ``CICharField``, ``CIEmailField``, and ``CITextField``
use a ``citext`` cast (:ticket:`28702`). use a ``citext`` cast (:ticket:`28702`).
* Fixed a regression in caching of a ``GenericForeignKey`` when the referenced
model instance uses multi-table inheritance (:ticket:`28856`).

View File

@ -48,6 +48,12 @@ class GenericRelationTests(TestCase):
TextLink.objects.create(content_object=oddrel) TextLink.objects.create(content_object=oddrel)
oddrel.delete() oddrel.delete()
def test_coerce_object_id_remote_field_cache_persistence(self):
restaurant = Restaurant.objects.create()
CharLink.objects.create(content_object=restaurant)
charlink = CharLink.objects.latest('pk')
self.assertIs(charlink.content_object, charlink.content_object)
def test_q_object_or(self): def test_q_object_or(self):
""" """
SQL query parameters for generic relations are properly SQL query parameters for generic relations are properly

View File

@ -93,3 +93,13 @@ class ForeignKeyTests(TestCase):
assert_app_model_resolved('model_fields') assert_app_model_resolved('model_fields')
assert_app_model_resolved('tests') assert_app_model_resolved('tests')
@isolate_apps('model_fields')
def test_to_python(self):
class Foo(models.Model):
pass
class Bar(models.Model):
fk = models.ForeignKey(Foo, models.CASCADE)
self.assertEqual(Bar._meta.get_field('fk').to_python('1'), 1)

View File

@ -29,12 +29,6 @@ class XmlSerializerTestCase(SerializersTestBase, TestCase):
</object> </object>
</django-objects>""" # NOQA </django-objects>""" # NOQA
@staticmethod
def _comparison_value(value):
# The XML serializer handles everything as strings, so comparisons
# need to be performed on the stringified value
return str(value)
@staticmethod @staticmethod
def _validate_output(serial_str): def _validate_output(serial_str):
try: try:

View File

@ -90,10 +90,6 @@ class SerializerRegistrationTests(SimpleTestCase):
class SerializersTestBase: class SerializersTestBase:
serializer_name = None # Set by subclasses to the serialization format name serializer_name = None # Set by subclasses to the serialization format name
@staticmethod
def _comparison_value(value):
return value
def setUp(self): def setUp(self):
sports = Category.objects.create(name="Sports") sports = Category.objects.create(name="Sports")
music = Category.objects.create(name="Music") music = Category.objects.create(name="Music")
@ -193,7 +189,7 @@ class SerializersTestBase:
self.assertFalse(self._get_field_values(serial_str, 'author')) self.assertFalse(self._get_field_values(serial_str, 'author'))
for obj in serializers.deserialize(self.serializer_name, serial_str): for obj in serializers.deserialize(self.serializer_name, serial_str):
self.assertEqual(obj.object.pk, self._comparison_value(self.joe.pk)) self.assertEqual(obj.object.pk, self.joe.pk)
def test_serialize_field_subset(self): def test_serialize_field_subset(self):
"""Output can be restricted to a subset of fields""" """Output can be restricted to a subset of fields"""