Fix #187: Preserve sorting from fieldset config (#207)

This commit is contained in:
Bruno Alla 2017-06-02 09:52:16 +01:00 committed by Jannis Leidel
parent 31c1e7b53c
commit 1cce582edc
3 changed files with 49 additions and 2 deletions

View file

@ -233,8 +233,9 @@ class ConstanceAdmin(admin.ModelAdmin):
assert fields_exist, "CONSTANCE_CONFIG_FIELDSETS contains fields that does not exist"
config_values = []
for name, options in settings.CONFIG.items():
if name in fields_list:
for name in fields_list:
options = settings.CONFIG.get(name)
if options:
config_values.append(
self.get_config_value(name, options, form, initial)
)

View file

@ -1,3 +1,4 @@
import mock
from django.contrib import admin
from django.contrib.auth.models import User, Permission
from django.contrib.contenttypes.models import ContentType
@ -58,3 +59,47 @@ class TestAdmin(TestCase):
response = self.options.changelist_view(request, {})
self.assertContains(response, 'LINEBREAK_VALUE')
self.assertContains(response, 'eggs<br />eggs')
@mock.patch('constance.admin.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.admin.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.admin.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')
)

View file

@ -12,6 +12,7 @@ basepython =
deps =
redis
coverage
mock
django-picklefield
django-18: Django>=1.8,<1.9
django-19: Django>=1.9,<1.10