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:
parent
ddf7d7ab02
commit
cd0b65bcf7
|
@ -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))
|
||||||
|
|
|
@ -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']
|
||||||
|
|
Loading…
Reference in New Issue