diff options
| author | Claude Paroz <claude@2xlibre.net> | 2013-11-21 22:18:52 +0100 |
|---|---|---|
| committer | Claude Paroz <claude@2xlibre.net> | 2013-11-21 22:18:52 +0100 |
| commit | 1718b5256cd65b8701e315e307c2eb2b5dd4c8d9 (patch) | |
| tree | 970db7894ea88b11a5c4ec8917163b8ffd4b3838 /tests/admin_ordering/tests.py | |
| parent | e6d5f7ae49cd4ffb0e4c6d69d77efcb33f0e5be7 (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.py | 22 |
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]) |
