summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Plant <L.Plant.98@cantab.net>2011-02-21 21:20:41 +0000
committerLuke Plant <L.Plant.98@cantab.net>2011-02-21 21:20:41 +0000
commit31d0f2fa29b766d4e739e8ad650b43435b48dfbf (patch)
tree86183cdefa2a5c7035bf0019d03cf76983adbead
parent25c217bc170d275a2db65fd9c9faa064797d4b2f (diff)
[1.2.X] Fixed #11058 - list_display_links doesn't allow callables not defined in the model
Thanks to dvine for the report and julien for the patch. Backport of [15619] from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.2.X@15621 bcc190cf-cafb-0310-a4f2-bffc1f526a37
-rw-r--r--django/contrib/admin/validation.py3
-rw-r--r--docs/ref/contrib/admin/index.txt8
-rw-r--r--tests/regressiontests/modeladmin/models.py5
-rw-r--r--tests/regressiontests/modeladmin/tests.py18
4 files changed, 24 insertions, 10 deletions
diff --git a/django/contrib/admin/validation.py b/django/contrib/admin/validation.py
index bee28912af..64cafde812 100644
--- a/django/contrib/admin/validation.py
+++ b/django/contrib/admin/validation.py
@@ -45,9 +45,8 @@ def validate(cls, model):
if hasattr(cls, 'list_display_links'):
check_isseq(cls, 'list_display_links', cls.list_display_links)
for idx, field in enumerate(cls.list_display_links):
- fetch_attr(cls, model, opts, 'list_display_links[%d]' % idx, field)
if field not in cls.list_display:
- raise ImproperlyConfigured("'%s.list_display_links[%d]'"
+ raise ImproperlyConfigured("'%s.list_display_links[%d]' "
"refers to '%s' which is not defined in 'list_display'."
% (cls.__name__, idx, field))
diff --git a/docs/ref/contrib/admin/index.txt b/docs/ref/contrib/admin/index.txt
index 7dde9ecae6..18ea121d40 100644
--- a/docs/ref/contrib/admin/index.txt
+++ b/docs/ref/contrib/admin/index.txt
@@ -408,12 +408,12 @@ subclass::
By default, the change list page will link the first column -- the first
field specified in ``list_display`` -- to the change page for each item.
- But``list_display_links`` lets you change which columns are linked. Set
- ``list_display_links`` to a list or tuple of field names (in the same
+ But ``list_display_links`` lets you change which columns are linked. Set
+ ``list_display_links`` to a list or tuple of fields (in the same
format as ``list_display``) to link.
- ``list_display_links`` can specify one or many field names. As long as the
- field names appear in ``list_display``, Django doesn't care how many (or
+ ``list_display_links`` can specify one or many fields. As long as the
+ fields appear in ``list_display``, Django doesn't care how many (or
how few) fields are linked. The only requirement is: If you want to use
``list_display_links``, you must define ``list_display``.
diff --git a/tests/regressiontests/modeladmin/models.py b/tests/regressiontests/modeladmin/models.py
index 20dfe2ce98..cb2e3d1b0b 100644
--- a/tests/regressiontests/modeladmin/models.py
+++ b/tests/regressiontests/modeladmin/models.py
@@ -8,7 +8,7 @@ class Band(models.Model):
name = models.CharField(max_length=100)
bio = models.TextField()
sign_date = models.DateField()
-
+
def __unicode__(self):
return self.name
@@ -32,5 +32,8 @@ class ValidationTestModel(models.Model):
pub_date = models.DateTimeField()
band = models.ForeignKey(Band)
+ def decade_published_in(self):
+ return self.pub_date.strftime('%Y')[:3] + "0's"
+
class ValidationTestInlineModel(models.Model):
parent = models.ForeignKey(ValidationTestModel)
diff --git a/tests/regressiontests/modeladmin/tests.py b/tests/regressiontests/modeladmin/tests.py
index b13a0ec952..5f975f46d7 100644
--- a/tests/regressiontests/modeladmin/tests.py
+++ b/tests/regressiontests/modeladmin/tests.py
@@ -778,8 +778,13 @@ class ValidationTests(unittest.TestCase):
ValidationTestModel,
)
+ def a_callable(obj):
+ pass
+
class ValidationTestModelAdmin(ModelAdmin):
- list_display = ('name',)
+ def a_method(self, obj):
+ pass
+ list_display = ('name', 'decade_published_in', 'a_method', a_callable)
validate(ValidationTestModelAdmin, ValidationTestModel)
@@ -801,7 +806,7 @@ class ValidationTests(unittest.TestCase):
self.assertRaisesErrorWithMessage(
ImproperlyConfigured,
- "'ValidationTestModelAdmin.list_display_links[0]' refers to 'non_existent_field' that is neither a field, method or property of model 'ValidationTestModel'.",
+ "'ValidationTestModelAdmin.list_display_links[0]' refers to 'non_existent_field' which is not defined in 'list_display'.",
validate,
ValidationTestModelAdmin,
ValidationTestModel,
@@ -812,15 +817,22 @@ class ValidationTests(unittest.TestCase):
self.assertRaisesErrorWithMessage(
ImproperlyConfigured,
- "'ValidationTestModelAdmin.list_display_links[0]'refers to 'name' which is not defined in 'list_display'.",
+ "'ValidationTestModelAdmin.list_display_links[0]' refers to 'name' which is not defined in 'list_display'.",
validate,
ValidationTestModelAdmin,
ValidationTestModel,
)
+ def a_callable(obj):
+ pass
+
class ValidationTestModelAdmin(ModelAdmin):
list_display = ('name',)
list_display_links = ('name',)
+ def a_method(self, obj):
+ pass
+ list_display = ('name', 'decade_published_in', 'a_method', a_callable)
+ list_display_links = ('name', 'decade_published_in', 'a_method', a_callable)
validate(ValidationTestModelAdmin, ValidationTestModel)