mirror of
https://github.com/jazzband/django-constance.git
synced 2026-03-17 06:50:23 +00:00
* Add a Django system check that CONFIG_FIELDSETS accounts for all of CONFIG * Fix test (don't actually modify values when submitting form) and restore python2 compatibility
152 lines
6.1 KiB
Python
152 lines
6.1 KiB
Python
import mock
|
|
from django.contrib import admin
|
|
from django.contrib.auth.models import User, Permission
|
|
from django.contrib.contenttypes.models import ContentType
|
|
from django.core.exceptions import PermissionDenied
|
|
from django.http import HttpResponseRedirect
|
|
from django.template.defaultfilters import linebreaksbr
|
|
from django.test import TestCase, RequestFactory
|
|
from django.utils import six
|
|
|
|
from constance import settings
|
|
from constance.admin import Config
|
|
|
|
|
|
class TestAdmin(TestCase):
|
|
model = Config
|
|
|
|
def setUp(self):
|
|
super(TestAdmin, self).setUp()
|
|
self.rf = RequestFactory()
|
|
self.superuser = User.objects.create_superuser('admin', 'nimda', 'a@a.cz')
|
|
self.normaluser = User.objects.create_user('normal', 'nimda', 'b@b.cz')
|
|
self.normaluser.is_staff = True
|
|
self.normaluser.save()
|
|
self.options = admin.site._registry[self.model]
|
|
|
|
def test_changelist(self):
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.superuser
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
def test_custom_auth(self):
|
|
settings.SUPERUSER_ONLY = False
|
|
self.client.login(username='normal', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.normaluser
|
|
self.assertRaises(PermissionDenied,
|
|
self.options.changelist_view,
|
|
request, {})
|
|
self.assertFalse(request.user.has_perm('constance.change_config'))
|
|
|
|
# reload user to reset permission cache
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = User.objects.get(pk=self.normaluser.pk)
|
|
|
|
request.user.user_permissions.add(Permission.objects.get(codename='change_config'))
|
|
self.assertTrue(request.user.has_perm('constance.change_config'))
|
|
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
def test_str(self):
|
|
ct = ContentType.objects.get(app_label='constance', model='config')
|
|
self.assertEqual(six.text_type(ct), 'config')
|
|
|
|
def test_linebreaks(self):
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.superuser
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertContains(response, 'LINEBREAK_VALUE')
|
|
self.assertContains(response, linebreaksbr('eggs\neggs'))
|
|
|
|
@mock.patch('constance.settings.CONFIG_FIELDSETS', {
|
|
'Numbers': ('LONG_VALUE', 'INT_VALUE',),
|
|
'Text': ('STRING_VALUE', 'UNICODE_VALUE'),
|
|
})
|
|
def test_fieldset_headers(self):
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.superuser
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertContains(response, '<h2>Numbers</h2>')
|
|
self.assertContains(response, '<h2>Text</h2>')
|
|
|
|
@mock.patch('constance.settings.CONFIG_FIELDSETS', {
|
|
'FieldSetOne': ('INT_VALUE',)
|
|
})
|
|
@mock.patch('constance.settings.CONFIG', {
|
|
'INT_VALUE': (1, 'some int'),
|
|
})
|
|
@mock.patch('constance.settings.IGNORE_ADMIN_VERSION_CHECK', True)
|
|
def test_submit(self):
|
|
"""
|
|
Test that submitting the admin page results in an http redirect when
|
|
everything is in order.
|
|
"""
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.post('/admin/constance/config/', data={
|
|
"INT_VALUE": settings.CONFIG['INT_VALUE'][0],
|
|
"version": "123",
|
|
})
|
|
request.user = self.superuser
|
|
request._dont_enforce_csrf_checks = True
|
|
with mock.patch("constance.admin.ConstanceForm.save"):
|
|
with mock.patch("django.contrib.messages.add_message"):
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertIsInstance(response, HttpResponseRedirect)
|
|
|
|
@mock.patch('constance.settings.CONFIG_FIELDSETS', {
|
|
'Numbers': ('LONG_VALUE', 'INT_VALUE',),
|
|
'Text': ('STRING_VALUE', 'UNICODE_VALUE'),
|
|
})
|
|
def test_inconsistent_fieldset_submit(self):
|
|
"""
|
|
Test that the admin page warns users if the CONFIG_FIELDSETS setting
|
|
doesn't account for every field in CONFIG.
|
|
"""
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.post('/admin/constance/config/', data=None)
|
|
request.user = self.superuser
|
|
request._dont_enforce_csrf_checks = True
|
|
response = self.options.changelist_view(request, {})
|
|
self.assertContains(response, 'is missing field(s)')
|
|
|
|
@mock.patch('constance.settings.CONFIG_FIELDSETS', {
|
|
'Numbers': ('LONG_VALUE', 'INT_VALUE',),
|
|
})
|
|
def test_fieldset_ordering_1(self):
|
|
"""Ordering of inner list should be preserved"""
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.superuser
|
|
response = self.options.changelist_view(request, {})
|
|
response.render()
|
|
content_str = response.content.decode('utf-8')
|
|
self.assertGreater(
|
|
content_str.find('INT_VALUE'),
|
|
content_str.find('LONG_VALUE')
|
|
)
|
|
|
|
@mock.patch('constance.settings.CONFIG_FIELDSETS', {
|
|
'Numbers': ('INT_VALUE', 'LONG_VALUE', ),
|
|
})
|
|
def test_fieldset_ordering_2(self):
|
|
"""Ordering of inner list should be preserved"""
|
|
self.client.login(username='admin', password='nimda')
|
|
request = self.rf.get('/admin/constance/config/')
|
|
request.user = self.superuser
|
|
response = self.options.changelist_view(request, {})
|
|
response.render()
|
|
content_str = response.content.decode('utf-8')
|
|
self.assertGreater(
|
|
content_str.find('LONG_VALUE'),
|
|
content_str.find('INT_VALUE')
|
|
)
|
|
|
|
def test_labels(self):
|
|
self.assertEqual(type(self.model._meta.label), str)
|
|
self.assertEqual(type(self.model._meta.label_lower), str)
|