summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorRussell Keith-Magee <russell@keith-magee.com>2011-02-25 15:14:26 +0000
committerRussell Keith-Magee <russell@keith-magee.com>2011-02-25 15:14:26 +0000
commit4d70d48ecbfe2b972c55c3b4fa1237dfe54f5b6b (patch)
treee2fdc9f39d521163687d1de428f01f8113468d8f /tests
parentb97b9fb8f8fcc5aceb924c10c343e7a5eb4990bc (diff)
Fixed #8528 -- Ensure that null values are displayed as a filtering option in the admin if a field allows nulls. Thanks to StevenPotter for the report, and oyvind, marcob, Simon Meers and Julien Phalip for the patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@15649 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'tests')
-rw-r--r--tests/regressiontests/admin_filterspecs/__init__.py0
-rw-r--r--tests/regressiontests/admin_filterspecs/models.py11
-rw-r--r--tests/regressiontests/admin_filterspecs/tests.py171
3 files changed, 182 insertions, 0 deletions
diff --git a/tests/regressiontests/admin_filterspecs/__init__.py b/tests/regressiontests/admin_filterspecs/__init__.py
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/tests/regressiontests/admin_filterspecs/__init__.py
diff --git a/tests/regressiontests/admin_filterspecs/models.py b/tests/regressiontests/admin_filterspecs/models.py
new file mode 100644
index 0000000000..fe9fdfe1bd
--- /dev/null
+++ b/tests/regressiontests/admin_filterspecs/models.py
@@ -0,0 +1,11 @@
+from django.db import models
+from django.contrib.auth.models import User
+
+class Book(models.Model):
+ title = models.CharField(max_length=25)
+ year = models.PositiveIntegerField(null=True, blank=True)
+ author = models.ForeignKey(User, related_name='books_authored', blank=True, null=True)
+ contributors = models.ManyToManyField(User, related_name='books_contributed', blank=True, null=True)
+
+ def __unicode__(self):
+ return self.title
diff --git a/tests/regressiontests/admin_filterspecs/tests.py b/tests/regressiontests/admin_filterspecs/tests.py
new file mode 100644
index 0000000000..64a6ac700e
--- /dev/null
+++ b/tests/regressiontests/admin_filterspecs/tests.py
@@ -0,0 +1,171 @@
+from django.contrib.auth.admin import UserAdmin
+from django.test import TestCase
+from django.test.client import RequestFactory
+from django.contrib.auth.models import User
+from django.contrib import admin
+from django.contrib.admin.views.main import ChangeList
+from django.utils.encoding import force_unicode
+
+from models import Book
+
+class FilterSpecsTests(TestCase):
+
+ def setUp(self):
+ # Users
+ alfred = User.objects.create_user('alfred', 'alfred@example.com')
+ bob = User.objects.create_user('bob', 'alfred@example.com')
+ lisa = User.objects.create_user('lisa', 'lisa@example.com')
+
+ #Books
+ bio_book = Book.objects.create(title='Django: a biography', year=1999, author=alfred)
+ django_book = Book.objects.create(title='The Django Book', year=None, author=bob)
+ gipsy_book = Book.objects.create(title='Gipsy guitar for dummies', year=2002)
+ gipsy_book.contributors = [bob, lisa]
+ gipsy_book.save()
+
+ self.request_factory = RequestFactory()
+
+
+ def get_changelist(self, request, model, modeladmin):
+ return ChangeList(request, model, modeladmin.list_display, modeladmin.list_display_links,
+ modeladmin.list_filter, modeladmin.date_hierarchy, modeladmin.search_fields,
+ modeladmin.list_select_related, modeladmin.list_per_page, modeladmin.list_editable, modeladmin)
+
+ def test_AllValuesFilterSpec(self):
+ modeladmin = BookAdmin(Book, admin.site)
+
+ request = self.request_factory.get('/', {'year__isnull': 'True'})
+ changelist = self.get_changelist(request, Book, modeladmin)
+
+ # Make sure changelist.get_query_set() does not raise IncorrectLookupParameters
+ queryset = changelist.get_query_set()
+
+ # Make sure the last choice is None and is selected
+ filterspec = changelist.get_filters(request)[0][0]
+ self.assertEquals(force_unicode(filterspec.title()), u'year')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[-1]['selected'], True)
+ self.assertEquals(choices[-1]['query_string'], '?year__isnull=True')
+
+ request = self.request_factory.get('/', {'year': '2002'})
+ changelist = self.get_changelist(request, Book, modeladmin)
+
+ # Make sure the correct choice is selected
+ filterspec = changelist.get_filters(request)[0][0]
+ self.assertEquals(force_unicode(filterspec.title()), u'year')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[2]['selected'], True)
+ self.assertEquals(choices[2]['query_string'], '?year=2002')
+
+ def test_RelatedFilterSpec_ForeignKey(self):
+ modeladmin = BookAdmin(Book, admin.site)
+
+ request = self.request_factory.get('/', {'author__isnull': 'True'})
+ changelist = ChangeList(request, Book, modeladmin.list_display, modeladmin.list_display_links,
+ modeladmin.list_filter, modeladmin.date_hierarchy, modeladmin.search_fields,
+ modeladmin.list_select_related, modeladmin.list_per_page, modeladmin.list_editable, modeladmin)
+
+ # Make sure changelist.get_query_set() does not raise IncorrectLookupParameters
+ queryset = changelist.get_query_set()
+
+ # Make sure the last choice is None and is selected
+ filterspec = changelist.get_filters(request)[0][1]
+ self.assertEquals(force_unicode(filterspec.title()), u'author')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[-1]['selected'], True)
+ self.assertEquals(choices[-1]['query_string'], '?author__isnull=True')
+
+ request = self.request_factory.get('/', {'author__id__exact': '1'})
+ changelist = self.get_changelist(request, Book, modeladmin)
+
+ # Make sure the correct choice is selected
+ filterspec = changelist.get_filters(request)[0][1]
+ self.assertEquals(force_unicode(filterspec.title()), u'author')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[1]['selected'], True)
+ self.assertEquals(choices[1]['query_string'], '?author__id__exact=1')
+
+ def test_RelatedFilterSpec_ManyToMany(self):
+ modeladmin = BookAdmin(Book, admin.site)
+
+ request = self.request_factory.get('/', {'contributors__isnull': 'True'})
+ changelist = self.get_changelist(request, Book, modeladmin)
+
+ # Make sure changelist.get_query_set() does not raise IncorrectLookupParameters
+ queryset = changelist.get_query_set()
+
+ # Make sure the last choice is None and is selected
+ filterspec = changelist.get_filters(request)[0][2]
+ self.assertEquals(force_unicode(filterspec.title()), u'user')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[-1]['selected'], True)
+ self.assertEquals(choices[-1]['query_string'], '?contributors__isnull=True')
+
+ request = self.request_factory.get('/', {'contributors__id__exact': '2'})
+ changelist = self.get_changelist(request, Book, modeladmin)
+
+ # Make sure the correct choice is selected
+ filterspec = changelist.get_filters(request)[0][2]
+ self.assertEquals(force_unicode(filterspec.title()), u'user')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[2]['selected'], True)
+ self.assertEquals(choices[2]['query_string'], '?contributors__id__exact=2')
+
+
+ def test_RelatedFilterSpec_reverse_relationships(self):
+ modeladmin = CustomUserAdmin(User, admin.site)
+
+ # FK relationship -----
+ request = self.request_factory.get('/', {'books_authored__isnull': 'True'})
+ changelist = self.get_changelist(request, User, modeladmin)
+
+ # Make sure changelist.get_query_set() does not raise IncorrectLookupParameters
+ queryset = changelist.get_query_set()
+
+ # Make sure the last choice is None and is selected
+ filterspec = changelist.get_filters(request)[0][0]
+ self.assertEquals(force_unicode(filterspec.title()), u'book')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[-1]['selected'], True)
+ self.assertEquals(choices[-1]['query_string'], '?books_authored__isnull=True')
+
+ request = self.request_factory.get('/', {'books_authored__id__exact': '1'})
+ changelist = self.get_changelist(request, User, modeladmin)
+
+ # Make sure the correct choice is selected
+ filterspec = changelist.get_filters(request)[0][0]
+ self.assertEquals(force_unicode(filterspec.title()), u'book')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[1]['selected'], True)
+ self.assertEquals(choices[1]['query_string'], '?books_authored__id__exact=1')
+
+ # M2M relationship -----
+ request = self.request_factory.get('/', {'books_contributed__isnull': 'True'})
+ changelist = self.get_changelist(request, User, modeladmin)
+
+ # Make sure changelist.get_query_set() does not raise IncorrectLookupParameters
+ queryset = changelist.get_query_set()
+
+ # Make sure the last choice is None and is selected
+ filterspec = changelist.get_filters(request)[0][1]
+ self.assertEquals(force_unicode(filterspec.title()), u'book')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[-1]['selected'], True)
+ self.assertEquals(choices[-1]['query_string'], '?books_contributed__isnull=True')
+
+ request = self.request_factory.get('/', {'books_contributed__id__exact': '2'})
+ changelist = self.get_changelist(request, User, modeladmin)
+
+ # Make sure the correct choice is selected
+ filterspec = changelist.get_filters(request)[0][1]
+ self.assertEquals(force_unicode(filterspec.title()), u'book')
+ choices = list(filterspec.choices(changelist))
+ self.assertEquals(choices[2]['selected'], True)
+ self.assertEquals(choices[2]['query_string'], '?books_contributed__id__exact=2')
+
+class CustomUserAdmin(UserAdmin):
+ list_filter = ('books_authored', 'books_contributed')
+
+class BookAdmin(admin.ModelAdmin):
+ list_filter = ('year', 'author', 'contributors')
+ order_by = '-id'