1
0
mirror of https://github.com/django/django.git synced 2025-10-25 14:46:09 +00:00

Fixed #22810 -- Corrected admin changelist count for list filters that filter by default.

This commit is contained in:
Nick Sandford
2015-11-07 13:01:25 +00:00
committed by Tim Graham
parent ad167502f3
commit 5fa7b592b3
3 changed files with 35 additions and 11 deletions

View File

@@ -174,14 +174,8 @@ class ChangeList(object):
result_count = paginator.count result_count = paginator.count
# Get the total number of objects, with no admin filters applied. # Get the total number of objects, with no admin filters applied.
# Perform a slight optimization:
# full_result_count is equal to paginator.count if no filters
# were applied
if self.model_admin.show_full_result_count: if self.model_admin.show_full_result_count:
if self.get_filters_params() or self.params.get(SEARCH_VAR):
full_result_count = self.root_queryset.count() full_result_count = self.root_queryset.count()
else:
full_result_count = result_count
else: else:
full_result_count = None full_result_count = None
can_show_all = result_count <= self.list_max_show_all can_show_all = result_count <= self.list_max_show_all

View File

@@ -43,6 +43,22 @@ class DecadeListFilter(SimpleListFilter):
return queryset.filter(year__gte=2000, year__lte=2009) return queryset.filter(year__gte=2000, year__lte=2009)
class NotNinetiesListFilter(SimpleListFilter):
title = "Not nineties books"
parameter_name = "book_year"
def lookups(self, request, model_admin):
return (
('the 90s', "the 1990's"),
)
def queryset(self, request, queryset):
if self.value() == 'the 90s':
return queryset.filter(year__gte=1990, year__lte=1999)
else:
return queryset.exclude(year__gte=1990, year__lte=1999)
class DecadeListFilterWithTitleAndParameter(DecadeListFilter): class DecadeListFilterWithTitleAndParameter(DecadeListFilter):
title = 'publication decade' title = 'publication decade'
parameter_name = 'publication-decade' parameter_name = 'publication-decade'
@@ -179,6 +195,10 @@ class DecadeFilterBookAdmin(ModelAdmin):
ordering = ('-id',) ordering = ('-id',)
class NotNinetiesListFilterAdmin(ModelAdmin):
list_filter = (NotNinetiesListFilter,)
class DecadeFilterBookAdminWithoutTitle(ModelAdmin): class DecadeFilterBookAdminWithoutTitle(ModelAdmin):
list_filter = (DecadeListFilterWithoutTitle,) list_filter = (DecadeListFilterWithoutTitle,)
@@ -1026,3 +1046,14 @@ class ListFiltersTests(TestCase):
_test_choices(self.request_factory.get('/', {'publication-decade': 'the 90s'}), _test_choices(self.request_factory.get('/', {'publication-decade': 'the 90s'}),
("All", "the 1980's")) ("All", "the 1980's"))
def test_list_filter_queryset_filtered_by_default(self):
"""
A list filter that filters the queryset by default gives the correct
full_result_count.
"""
modeladmin = NotNinetiesListFilterAdmin(Book, site)
request = self.request_factory.get('/', {})
changelist = self.get_changelist(request, Book, modeladmin)
changelist.get_results(request)
self.assertEqual(changelist.full_result_count, 4)

View File

@@ -3756,13 +3756,12 @@ class AdminCustomQuerysetTest(TestCase):
Person.objects.create(name='person2', gender=2) Person.objects.create(name='person2', gender=2)
changelist_url = reverse('admin:admin_views_person_changelist') changelist_url = reverse('admin:admin_views_person_changelist')
# 4 queries are expected: 1 for the session, 1 for the user, # 5 queries are expected: 1 for the session, 1 for the user,
# 1 for the count and 1 for the objects on the page # 2 for the counts and 1 for the objects on the page
with self.assertNumQueries(4): with self.assertNumQueries(5):
resp = self.client.get(changelist_url) resp = self.client.get(changelist_url)
self.assertEqual(resp.context['selection_note'], '0 of 2 selected') self.assertEqual(resp.context['selection_note'], '0 of 2 selected')
self.assertEqual(resp.context['selection_note_all'], 'All 2 selected') self.assertEqual(resp.context['selection_note_all'], 'All 2 selected')
# here one more count(*) query will run, because filters were applied
with self.assertNumQueries(5): with self.assertNumQueries(5):
extra = {'q': 'not_in_name'} extra = {'q': 'not_in_name'}
resp = self.client.get(changelist_url, extra) resp = self.client.get(changelist_url, extra)