2012-06-07 18:08:47 +02:00
|
|
|
from __future__ import absolute_import, unicode_literals
|
2011-10-13 18:51:33 +00:00
|
|
|
|
2012-10-18 20:58:52 -03:00
|
|
|
import warnings
|
|
|
|
|
2012-09-24 22:02:59 -03:00
|
|
|
from django.contrib.admin.util import quote
|
2011-09-20 18:30:06 +00:00
|
|
|
from django.core.urlresolvers import reverse
|
|
|
|
from django.template.response import TemplateResponse
|
|
|
|
from django.test import TestCase
|
2012-04-30 21:38:44 +03:00
|
|
|
from django.test.utils import override_settings
|
2011-09-20 18:30:06 +00:00
|
|
|
|
2012-10-18 20:58:52 -03:00
|
|
|
from .models import Action, Person, City
|
2011-09-20 18:30:06 +00:00
|
|
|
|
|
|
|
|
2012-04-30 21:38:44 +03:00
|
|
|
@override_settings(PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',))
|
2011-09-20 18:30:06 +00:00
|
|
|
class AdminCustomUrlsTest(TestCase):
|
2012-08-26 17:54:49 -03:00
|
|
|
"""
|
|
|
|
Remember that:
|
|
|
|
* The Action model has a CharField PK.
|
|
|
|
* The ModelAdmin for Action customizes the add_view URL, it's
|
|
|
|
'<app name>/<model name>/!add/'
|
|
|
|
"""
|
2011-09-20 18:30:06 +00:00
|
|
|
fixtures = ['users.json', 'actions.json']
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.client.login(username='super', password='secret')
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.client.logout()
|
|
|
|
|
|
|
|
def testBasicAddGet(self):
|
|
|
|
"""
|
2012-08-26 17:54:49 -03:00
|
|
|
Ensure GET on the add_view works.
|
2011-09-20 18:30:06 +00:00
|
|
|
"""
|
|
|
|
response = self.client.get('/custom_urls/admin/admin_custom_urls/action/!add/')
|
|
|
|
self.assertIsInstance(response, TemplateResponse)
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
|
|
|
|
def testAddWithGETArgs(self):
|
2012-08-26 17:54:49 -03:00
|
|
|
"""
|
|
|
|
Ensure GET on the add_view plus specifying a field value in the query
|
|
|
|
string works.
|
|
|
|
"""
|
2011-09-20 18:30:06 +00:00
|
|
|
response = self.client.get('/custom_urls/admin/admin_custom_urls/action/!add/', {'name': 'My Action'})
|
|
|
|
self.assertEqual(response.status_code, 200)
|
2012-08-14 14:38:23 +02:00
|
|
|
self.assertContains(response, 'value="My Action"')
|
2011-09-20 18:30:06 +00:00
|
|
|
|
|
|
|
def testBasicAddPost(self):
|
|
|
|
"""
|
2012-08-26 17:54:49 -03:00
|
|
|
Ensure POST on add_view works.
|
2011-09-20 18:30:06 +00:00
|
|
|
"""
|
|
|
|
post_data = {
|
2012-06-07 18:08:47 +02:00
|
|
|
'_popup': '1',
|
|
|
|
"name": 'Action added through a popup',
|
|
|
|
"description": "Description of added action",
|
2011-09-20 18:30:06 +00:00
|
|
|
}
|
|
|
|
response = self.client.post('/custom_urls/admin/admin_custom_urls/action/!add/', post_data)
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertContains(response, 'dismissAddAnotherPopup')
|
|
|
|
self.assertContains(response, 'Action added through a popup')
|
|
|
|
|
|
|
|
def testAdminUrlsNoClash(self):
|
|
|
|
"""
|
2012-08-26 17:54:49 -03:00
|
|
|
Test that some admin URLs work correctly.
|
2011-09-20 18:30:06 +00:00
|
|
|
"""
|
|
|
|
# Should get the change_view for model instance with PK 'add', not show
|
|
|
|
# the add_view
|
|
|
|
response = self.client.get('/custom_urls/admin/admin_custom_urls/action/add/')
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertContains(response, 'Change action')
|
|
|
|
|
|
|
|
# Ditto, but use reverse() to build the URL
|
2012-08-26 17:54:49 -03:00
|
|
|
url = reverse('admin:%s_action_change' % Action._meta.app_label,
|
2012-09-24 22:02:59 -03:00
|
|
|
args=(quote('add'),))
|
2012-08-26 17:54:49 -03:00
|
|
|
response = self.client.get(url)
|
2011-09-20 18:30:06 +00:00
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertContains(response, 'Change action')
|
|
|
|
|
|
|
|
# Should correctly get the change_view for the model instance with the
|
2012-08-26 17:54:49 -03:00
|
|
|
# funny-looking PK (the one wth a 'path/to/html/document.html' value)
|
|
|
|
url = reverse('admin:%s_action_change' % Action._meta.app_label,
|
2012-09-24 22:02:59 -03:00
|
|
|
args=(quote("path/to/html/document.html"),))
|
2012-08-26 17:54:49 -03:00
|
|
|
response = self.client.get(url)
|
2011-09-20 18:30:06 +00:00
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertContains(response, 'Change action')
|
|
|
|
self.assertContains(response, 'value="path/to/html/document.html"')
|
2012-10-18 20:58:52 -03:00
|
|
|
|
|
|
|
|
|
|
|
@override_settings(PASSWORD_HASHERS=('django.contrib.auth.hashers.SHA1PasswordHasher',))
|
|
|
|
class CustomUrlsWorkflowTests(TestCase):
|
|
|
|
fixtures = ['users.json']
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.client.login(username='super', password='secret')
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
self.client.logout()
|
|
|
|
|
|
|
|
def test_old_argument_deprecation(self):
|
|
|
|
"""Test reporting of post_url_continue deprecation."""
|
|
|
|
post_data = {
|
|
|
|
'nick': 'johndoe',
|
|
|
|
}
|
|
|
|
cnt = Person.objects.count()
|
|
|
|
with warnings.catch_warnings(record=True) as w:
|
|
|
|
warnings.simplefilter("always")
|
|
|
|
response = self.client.post(reverse('admin:admin_custom_urls_person_add'), post_data)
|
|
|
|
self.assertEqual(response.status_code, 302)
|
|
|
|
self.assertEqual(Person.objects.count(), cnt + 1)
|
|
|
|
# We should get a DeprecationWarning
|
|
|
|
self.assertEqual(len(w), 1)
|
|
|
|
self.assertTrue(isinstance(w[0].message, DeprecationWarning))
|
|
|
|
|
|
|
|
def test_custom_add_another_redirect(self):
|
|
|
|
"""Test customizability of post-object-creation redirect URL."""
|
|
|
|
post_data = {
|
|
|
|
'name': 'Rome',
|
|
|
|
'_addanother': '1',
|
|
|
|
}
|
|
|
|
cnt = City.objects.count()
|
|
|
|
with warnings.catch_warnings(record=True) as w:
|
|
|
|
# POST to the view whose post-object-creation redir URL argument we
|
|
|
|
# are customizing (object creation)
|
|
|
|
response = self.client.post(reverse('admin:admin_custom_urls_city_add'), post_data)
|
|
|
|
self.assertEqual(City.objects.count(), cnt + 1)
|
|
|
|
# Check that it redirected to the URL we set
|
|
|
|
self.assertRedirects(response, reverse('admin:admin_custom_urls_city_changelist'))
|
|
|
|
self.assertEqual(len(w), 0) # We should get no DeprecationWarning
|