mirror of https://github.com/django/django.git
Fixed #11311 -- Reverted [10952], Refs #10785. Changeset [10952] caused problems with m2m relations between models that had non-integer primary keys. Thanks to Ronny for the report and test case.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@11007 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
c98a46c2be
commit
b38cf5db5c
|
@ -132,13 +132,13 @@ class RelatedField(object):
|
|||
v, field = getattr(v, v._meta.pk.name), v._meta.pk
|
||||
except AttributeError:
|
||||
pass
|
||||
if not field:
|
||||
field = self.rel.get_related_field()
|
||||
if lookup_type in ('range', 'in'):
|
||||
v = [v]
|
||||
v = field.get_db_prep_lookup(lookup_type, v)
|
||||
if isinstance(v, list):
|
||||
v = v[0]
|
||||
|
||||
if field:
|
||||
if lookup_type in ('range', 'in'):
|
||||
v = [v]
|
||||
v = field.get_db_prep_lookup(lookup_type, v)
|
||||
if isinstance(v, list):
|
||||
v = v[0]
|
||||
return v
|
||||
|
||||
if hasattr(value, 'as_sql') or hasattr(value, '_as_sql'):
|
||||
|
|
|
@ -136,11 +136,14 @@ Pass
|
|||
# Regression for #10785 -- Custom fields can be used for primary keys.
|
||||
>>> new_bar = Bar.objects.create()
|
||||
>>> new_foo = Foo.objects.create(bar=new_bar)
|
||||
>>> f = Foo.objects.get(bar=new_bar.pk)
|
||||
>>> f == new_foo
|
||||
True
|
||||
>>> f.bar == new_bar
|
||||
True
|
||||
|
||||
# FIXME: This still doesn't work, but will require some changes in
|
||||
# get_db_prep_lookup to fix it.
|
||||
# >>> f = Foo.objects.get(bar=new_bar.pk)
|
||||
# >>> f == new_foo
|
||||
# True
|
||||
# >>> f.bar == new_bar
|
||||
# True
|
||||
|
||||
>>> f = Foo.objects.get(bar=new_bar)
|
||||
>>> f == new_foo
|
||||
|
|
|
@ -33,6 +33,14 @@ class SelfReferChild(SelfRefer):
|
|||
class SelfReferChildSibling(SelfRefer):
|
||||
pass
|
||||
|
||||
# Many-to-Many relation between models, where one of the PK's isn't an Autofield
|
||||
class Line(models.Model):
|
||||
name = models.CharField(max_length=100)
|
||||
|
||||
class Worksheet(models.Model):
|
||||
id = models.CharField(primary_key=True, max_length=100)
|
||||
lines = models.ManyToManyField(Line, blank=True, null=True)
|
||||
|
||||
__test__ = {"regressions": """
|
||||
# Multiple m2m references to the same model or a different model must be
|
||||
# distinguished when accessing the relations through an instance attribute.
|
||||
|
@ -79,5 +87,11 @@ FieldError: Cannot resolve keyword 'porcupine' into field. Choices are: id, name
|
|||
>>> sr_sibling.related.all()
|
||||
[<SelfRefer: Hanna>]
|
||||
|
||||
# Regression for #11311 - The primary key for models in a m2m relation
|
||||
# doesn't have to be an AutoField
|
||||
>>> w = Worksheet(id='abc')
|
||||
>>> w.save()
|
||||
>>> w.delete()
|
||||
|
||||
"""
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue