summaryrefslogtreecommitdiff
path: root/tests/admin_ordering/tests.py
diff options
context:
space:
mode:
authorClaude Paroz <claude@2xlibre.net>2013-11-21 22:18:52 +0100
committerClaude Paroz <claude@2xlibre.net>2013-11-21 22:18:52 +0100
commit1718b5256cd65b8701e315e307c2eb2b5dd4c8d9 (patch)
tree970db7894ea88b11a5c4ec8917163b8ffd4b3838 /tests/admin_ordering/tests.py
parente6d5f7ae49cd4ffb0e4c6d69d77efcb33f0e5be7 (diff)
Fixed #21405 -- Prevented queryset overwrite in BaseModelAdmin
Thanks guido@20tab.com for the report and Tim Graham for the analyze.
Diffstat (limited to 'tests/admin_ordering/tests.py')
-rw-r--r--tests/admin_ordering/tests.py22
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/admin_ordering/tests.py b/tests/admin_ordering/tests.py
index d4252d5036..0d62951e75 100644
--- a/tests/admin_ordering/tests.py
+++ b/tests/admin_ordering/tests.py
@@ -147,3 +147,25 @@ class TestRelatedFieldsAdminOrdering(TestCase):
# should be ordered by rank (defined by the ModelAdmin)
self.check_ordering_of_field_choices([self.b1, self.b2])
+
+ def test_custom_queryset_still_wins(self):
+ """Test that custom queryset has still precedence (#21405)"""
+ class SongAdmin(admin.ModelAdmin):
+ # Exclude one of the two Bands from the querysets
+ def formfield_for_foreignkey(self, db_field, **kwargs):
+ if db_field.name == 'band':
+ kwargs["queryset"] = Band.objects.filter(rank__gt=2)
+ return super(SongAdmin, self).formfield_for_foreignkey(db_field, **kwargs)
+ def formfield_for_manytomany(self, db_field, **kwargs):
+ if db_field.name == 'other_interpreters':
+ kwargs["queryset"] = Band.objects.filter(rank__gt=2)
+ return super(SongAdmin, self).formfield_for_foreignkey(db_field, **kwargs)
+
+ class StaticOrderingBandAdmin(admin.ModelAdmin):
+ ordering = ('rank',)
+
+ admin.site.unregister(Song)
+ admin.site.register(Song, SongAdmin)
+ admin.site.register(Band, StaticOrderingBandAdmin)
+
+ self.check_ordering_of_field_choices([self.b2])