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:
Brian Rosner 2008-08-29 16:46:46 +00:00
parent ddf7d7ab02
commit cd0b65bcf7
2 changed files with 28 additions and 3 deletions

View File

@ -186,11 +186,11 @@ class ModelAdmin(BaseModelAdmin):
# Delegate to the appropriate method, based on the URL. # Delegate to the appropriate method, based on the URL.
if url is None: if url is None:
return self.changelist_view(request) return self.changelist_view(request)
elif url.endswith('add'): elif url == "add":
return self.add_view(request) return self.add_view(request)
elif url.endswith('history'): elif url.endswith('/history'):
return self.history_view(request, unquote(url[:-8])) return self.history_view(request, unquote(url[:-8]))
elif url.endswith('delete'): elif url.endswith('/delete'):
return self.delete_view(request, unquote(url[:-7])) return self.delete_view(request, unquote(url[:-7]))
else: else:
return self.change_view(request, unquote(url)) return self.change_view(request, unquote(url))

View File

@ -458,6 +458,31 @@ class AdminViewStringPrimaryKeyTest(TestCase):
response = self.client.get('/test_admin/admin/admin_views/modelwithstringprimarykey/%s/delete/' % quote(self.pk)) response = self.client.get('/test_admin/admin/admin_views/modelwithstringprimarykey/%s/delete/' % quote(self.pk))
should_contain = """<a href="../../%s/">%s</a>""" % (quote(self.pk), escape(self.pk)) should_contain = """<a href="../../%s/">%s</a>""" % (quote(self.pk), escape(self.pk))
self.assertContains(response, should_contain) 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): class SecureViewTest(TestCase):
fixtures = ['admin-views-users.xml'] fixtures = ['admin-views-users.xml']