mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #23112 -- Field.get_choices tries to index an iterable
This commit is contained in:
committed by
Florian Apolloner
parent
c2ab501bab
commit
97a38de230
@@ -25,7 +25,8 @@ from .models import (
|
||||
Foo, Bar, Whiz, BigD, BigS, BigIntegerModel, Post, NullBooleanModel,
|
||||
BooleanModel, PrimaryKeyCharModel, DataModel, Document, RenamedField,
|
||||
DateTimeModel, VerboseNameField, FksToBooleans, FkToChar, FloatModel,
|
||||
SmallIntegerModel, IntegerModel, PositiveSmallIntegerModel, PositiveIntegerModel)
|
||||
SmallIntegerModel, IntegerModel, PositiveSmallIntegerModel, PositiveIntegerModel,
|
||||
WhizIter, WhizIterEmpty)
|
||||
|
||||
|
||||
class BasicFieldTests(test.TestCase):
|
||||
@@ -375,6 +376,31 @@ class ChoicesTests(test.TestCase):
|
||||
self.assertEqual(Whiz(c=None).get_c_display(), None) # Blank value
|
||||
self.assertEqual(Whiz(c='').get_c_display(), '') # Empty value
|
||||
|
||||
def test_iterator_choices(self):
|
||||
"""
|
||||
Check that get_choices works with Iterators (#23112).
|
||||
"""
|
||||
self.assertEqual(WhizIter(c=1).c, 1) # A nested value
|
||||
self.assertEqual(WhizIter(c=9).c, 9) # Invalid value
|
||||
self.assertEqual(WhizIter(c=None).c, None) # Blank value
|
||||
self.assertEqual(WhizIter(c='').c, '') # Empty value
|
||||
|
||||
def test_empty_iterator_choices(self):
|
||||
"""
|
||||
Check that get_choices works with empty iterators (#23112).
|
||||
"""
|
||||
self.assertEqual(WhizIterEmpty(c="a").c, "a") # A nested value
|
||||
self.assertEqual(WhizIterEmpty(c="b").c, "b") # Invalid value
|
||||
self.assertEqual(WhizIterEmpty(c=None).c, None) # Blank value
|
||||
self.assertEqual(WhizIterEmpty(c='').c, '') # Empty value
|
||||
|
||||
def test_charfield_get_choices_with_blank_iterator(self):
|
||||
"""
|
||||
Check that get_choices works with an empty Iterator
|
||||
"""
|
||||
f = models.CharField(choices=(x for x in []))
|
||||
self.assertEqual(f.get_choices(include_blank=True), [('', '---------')])
|
||||
|
||||
|
||||
class SlugFieldTests(test.TestCase):
|
||||
def test_slugfield_max_length(self):
|
||||
|
||||
Reference in New Issue
Block a user