mirror of
				https://github.com/django/django.git
				synced 2025-11-03 21:25:09 +00:00 
			
		
		
		
	git-svn-id: http://code.djangoproject.com/svn/django/trunk@16976 bcc190cf-cafb-0310-a4f2-bffc1f526a37
		
			
				
	
	
		
			74 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from __future__ import absolute_import
 | 
						|
 | 
						|
from django.core.urlresolvers import reverse
 | 
						|
from django.template.response import TemplateResponse
 | 
						|
from django.test import TestCase
 | 
						|
 | 
						|
from .models import Action
 | 
						|
 | 
						|
 | 
						|
class AdminCustomUrlsTest(TestCase):
 | 
						|
    fixtures = ['users.json', 'actions.json']
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        self.client.login(username='super', password='secret')
 | 
						|
 | 
						|
    def tearDown(self):
 | 
						|
        self.client.logout()
 | 
						|
 | 
						|
    def testBasicAddGet(self):
 | 
						|
        """
 | 
						|
        A smoke test to ensure GET on the add_view works.
 | 
						|
        """
 | 
						|
        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):
 | 
						|
        response = self.client.get('/custom_urls/admin/admin_custom_urls/action/!add/', {'name': 'My Action'})
 | 
						|
        self.assertEqual(response.status_code, 200)
 | 
						|
        self.assertTrue(
 | 
						|
            'value="My Action"' in response.content,
 | 
						|
            "Couldn't find an input with the right value in the response."
 | 
						|
        )
 | 
						|
 | 
						|
    def testBasicAddPost(self):
 | 
						|
        """
 | 
						|
        A smoke test to ensure POST on add_view works.
 | 
						|
        """
 | 
						|
        post_data = {
 | 
						|
            '_popup': u'1',
 | 
						|
            "name": u'Action added through a popup',
 | 
						|
            "description": u"Description of added action",
 | 
						|
        }
 | 
						|
        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):
 | 
						|
        """
 | 
						|
        Test that some admin URLs work correctly. The model has a CharField
 | 
						|
        PK and the add_view URL has been customized.
 | 
						|
        """
 | 
						|
        # 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
 | 
						|
        path = reverse('admin:%s_action_change' % Action._meta.app_label,
 | 
						|
                args=('add',))
 | 
						|
        response = self.client.get(path)
 | 
						|
        self.assertEqual(response.status_code, 200)
 | 
						|
        self.assertContains(response, 'Change action')
 | 
						|
 | 
						|
        # Should correctly get the change_view for the model instance with the
 | 
						|
        # funny-looking PK
 | 
						|
        path = reverse('admin:%s_action_change' % Action._meta.app_label,
 | 
						|
                args=("path/to/html/document.html",))
 | 
						|
        response = self.client.get(path)
 | 
						|
        self.assertEqual(response.status_code, 200)
 | 
						|
        self.assertContains(response, 'Change action')
 | 
						|
        self.assertContains(response, 'value="path/to/html/document.html"')
 |