[1.6.x] Fixed #23604 -- Allowed related m2m fields to be references in the admin.

Thanks Simon Charette for review.

Backport of a24cf21722 from master
This commit is contained in:
Emmanuelle Delescolle 2014-10-05 20:06:51 +02:00 committed by Tim Graham
parent 0aad1f1ea9
commit c5c4bfa12a
7 changed files with 33 additions and 5 deletions

View File

@ -339,6 +339,11 @@ class BaseModelAdmin(six.with_metaclass(RenameBaseModelAdminMethods)):
except FieldDoesNotExist: except FieldDoesNotExist:
return False return False
# Check whether this model is the origin of a M2M relationship
# in which case to_field has to be the pk on this model.
if opts.many_to_many and field.primary_key:
return True
# Make sure at least one of the models registered for this site # Make sure at least one of the models registered for this site
# references this field through a FK or a M2M relationship. # references this field through a FK or a M2M relationship.
registered_models = set() registered_models = set()

View File

@ -4,12 +4,15 @@ Django 1.4.16 release notes
*Under development* *Under development*
Django 1.4.16 fixes a regression in the 1.4.14 security release and a bug Django 1.4.16 fixes a couple regressions in the 1.4.14 security release and a
preventing the use of some GEOS versions with GeoDjango. bug preventing the use of some GEOS versions with GeoDjango.
Bugfixes Bugfixes
======== ========
* Allowed related many-to-many fields to be referenced in the admin
(`#23604 <http://code.djangoproject.com/ticket/23604>`_).
* Allowed inline and hidden references to admin fields * Allowed inline and hidden references to admin fields
(`#23431 <http://code.djangoproject.com/ticket/23431>`_). (`#23431 <http://code.djangoproject.com/ticket/23431>`_).

View File

@ -4,10 +4,13 @@ Django 1.5.11 release notes
*Under development* *Under development*
Django 1.5.11 fixes a regression in the 1.5.9 security release. Django 1.5.11 fixes a couple regressions in the 1.5.9 security release.
Bugfixes Bugfixes
======== ========
* Allowed related many-to-many fields to be referenced in the admin
(`#23604 <http://code.djangoproject.com/ticket/23604>`_).
* Allowed inline and hidden references to admin fields * Allowed inline and hidden references to admin fields
(`#23431 <http://code.djangoproject.com/ticket/23431>`_). (`#23431 <http://code.djangoproject.com/ticket/23431>`_).

View File

@ -4,9 +4,12 @@ Django 1.6.8 release notes
*Under development* *Under development*
Django 1.6.8 fixes a regression in the 1.6.6 security release. Django 1.6.8 fixes a couple regressions in the 1.6.6 security release.
Bugfixes Bugfixes
======== ========
* Allowed related many-to-many fields to be referenced in the admin
(:ticket:`23604`).
* Allowed inline and hidden references to admin fields (:ticket:`23431`). * Allowed inline and hidden references to admin fields (:ticket:`23431`).

View File

@ -31,7 +31,7 @@ from .models import (Article, Chapter, Account, Media, Child, Parent, Picture,
AdminOrderedCallable, Report, Color2, UnorderedObject, MainPrepopulated, AdminOrderedCallable, Report, Color2, UnorderedObject, MainPrepopulated,
RelatedPrepopulated, UndeletableObject, UserMessenger, Simple, Choice, RelatedPrepopulated, UndeletableObject, UserMessenger, Simple, Choice,
ShortMessage, Telegram, ReferencedByParent, ChildOfReferer, M2MReference, ShortMessage, Telegram, ReferencedByParent, ChildOfReferer, M2MReference,
ReferencedByInline, InlineReference, InlineReferer) ReferencedByInline, InlineReference, InlineReferer, Ingredient)
def callable_year(dt_value): def callable_year(dt_value):
@ -789,6 +789,7 @@ site.register(Color2, CustomTemplateFilterColorAdmin)
site.register(Simple, AttributeErrorRaisingAdmin) site.register(Simple, AttributeErrorRaisingAdmin)
site.register(UserMessenger, MessageTestingAdmin) site.register(UserMessenger, MessageTestingAdmin)
site.register(Choice, ChoiceList) site.register(Choice, ChoiceList)
site.register(Ingredient)
# Register core models we need in our tests # Register core models we need in our tests
from django.contrib.auth.models import User, Group from django.contrib.auth.models import User, Group

View File

@ -716,3 +716,12 @@ class InlineReference(models.Model):
class InlineReferer(models.Model): class InlineReferer(models.Model):
refs = models.ManyToManyField(InlineReference) refs = models.ManyToManyField(InlineReference)
# Models for #23604
class Recipe(models.Model):
name = models.CharField(max_length=20)
class Ingredient(models.Model):
name = models.CharField(max_length=20)
recipes = models.ManyToManyField('Recipe', related_name='ingredients')

View File

@ -599,6 +599,10 @@ class AdminViewBasicTest(AdminViewBasicTestCase):
response = self.client.get("/test_admin/admin/admin_views/m2mreference/", {TO_FIELD_VAR: 'id'}) response = self.client.get("/test_admin/admin/admin_views/m2mreference/", {TO_FIELD_VAR: 'id'})
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 200)
# #23604 - Specifying the pk of this model should be allowed when this model defines a m2m relationship
response = self.client.get("/test_admin/admin/admin_views/ingredient/", {TO_FIELD_VAR: 'id'})
self.assertEqual(response.status_code, 200)
# #23329 - Specifying a field that is not refered by any other model directly registered # #23329 - Specifying a field that is not refered by any other model directly registered
# to this admin site but registered through inheritance should be allowed. # to this admin site but registered through inheritance should be allowed.
response = self.client.get("/test_admin/admin/admin_views/referencedbyparent/", {TO_FIELD_VAR: 'id'}) response = self.client.get("/test_admin/admin/admin_views/referencedbyparent/", {TO_FIELD_VAR: 'id'})