mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #7982 -- Corrected ModelAdmin url dispatching to ensure it matching exactly what it needs and doesn't stomp on primary key space. 'add' is a lost cause for now. This originated from #6470. Thanks jdetaeye for the original patch and basith for providing test cases.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@8704 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -186,11 +186,11 @@ class ModelAdmin(BaseModelAdmin):
|
||||
# Delegate to the appropriate method, based on the URL.
|
||||
if url is None:
|
||||
return self.changelist_view(request)
|
||||
elif url.endswith('add'):
|
||||
elif url == "add":
|
||||
return self.add_view(request)
|
||||
elif url.endswith('history'):
|
||||
elif url.endswith('/history'):
|
||||
return self.history_view(request, unquote(url[:-8]))
|
||||
elif url.endswith('delete'):
|
||||
elif url.endswith('/delete'):
|
||||
return self.delete_view(request, unquote(url[:-7]))
|
||||
else:
|
||||
return self.change_view(request, unquote(url))
|
||||
|
@@ -459,6 +459,31 @@ class AdminViewStringPrimaryKeyTest(TestCase):
|
||||
should_contain = """<a href="../../%s/">%s</a>""" % (quote(self.pk), escape(self.pk))
|
||||
self.assertContains(response, should_contain)
|
||||
|
||||
def test_url_conflicts_with_add(self):
|
||||
"A model with a primary key that ends with add should be visible"
|
||||
add_model = ModelWithStringPrimaryKey(id="i have something to add")
|
||||
add_model.save()
|
||||
response = self.client.get('/test_admin/admin/admin_views/modelwithstringprimarykey/%s/' % quote(add_model.pk))
|
||||
should_contain = """<h1>Change model with string primary key</h1>"""
|
||||
self.assertContains(response, should_contain)
|
||||
|
||||
def test_url_conflicts_with_delete(self):
|
||||
"A model with a primary key that ends with delete should be visible"
|
||||
delete_model = ModelWithStringPrimaryKey(id="delete")
|
||||
delete_model.save()
|
||||
response = self.client.get('/test_admin/admin/admin_views/modelwithstringprimarykey/%s/' % quote(delete_model.pk))
|
||||
should_contain = """<h1>Change model with string primary key</h1>"""
|
||||
self.assertContains(response, should_contain)
|
||||
|
||||
def test_url_conflicts_with_history(self):
|
||||
"A model with a primary key that ends with history should be visible"
|
||||
history_model = ModelWithStringPrimaryKey(id="history")
|
||||
history_model.save()
|
||||
response = self.client.get('/test_admin/admin/admin_views/modelwithstringprimarykey/%s/' % quote(history_model.pk))
|
||||
should_contain = """<h1>Change model with string primary key</h1>"""
|
||||
self.assertContains(response, should_contain)
|
||||
|
||||
|
||||
class SecureViewTest(TestCase):
|
||||
fixtures = ['admin-views-users.xml']
|
||||
|
||||
|
Reference in New Issue
Block a user