mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Migrated admin_ordering doctests. Thanks to Sebastian Hillig.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@13881 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
39
tests/regressiontests/admin_ordering/tests.py
Normal file
39
tests/regressiontests/admin_ordering/tests.py
Normal file
@@ -0,0 +1,39 @@
|
||||
from django.test import TestCase
|
||||
from django.contrib.admin.options import ModelAdmin
|
||||
|
||||
from models import Band
|
||||
|
||||
class TestAdminOrdering(TestCase):
|
||||
"""
|
||||
Let's make sure that ModelAdmin.queryset uses the ordering we define in
|
||||
ModelAdmin rather that ordering defined in the model's inner Meta
|
||||
class.
|
||||
"""
|
||||
|
||||
def setUp(self):
|
||||
b1 = Band(name='Aerosmith', bio='', rank=3)
|
||||
b1.save()
|
||||
b2 = Band(name='Radiohead', bio='', rank=1)
|
||||
b2.save()
|
||||
b3 = Band(name='Van Halen', bio='', rank=2)
|
||||
b3.save()
|
||||
|
||||
def test_default_ordering(self):
|
||||
"""
|
||||
The default ordering should be by name, as specified in the inner Meta
|
||||
class.
|
||||
"""
|
||||
ma = ModelAdmin(Band, None)
|
||||
names = [b.name for b in ma.queryset(None)]
|
||||
self.assertEqual([u'Aerosmith', u'Radiohead', u'Van Halen'], names)
|
||||
|
||||
def test_specified_ordering(self):
|
||||
"""
|
||||
Let's use a custom ModelAdmin that changes the ordering, and make sure
|
||||
it actually changes.
|
||||
"""
|
||||
class BandAdmin(ModelAdmin):
|
||||
ordering = ('rank',) # default ordering is ('name',)
|
||||
ma = BandAdmin(Band, None)
|
||||
names = [b.name for b in ma.queryset(None)]
|
||||
self.assertEqual([u'Radiohead', u'Van Halen', u'Aerosmith'], names)
|
Reference in New Issue
Block a user