Added more tests for model field choices validation.

This commit is contained in:
François Freitag 2018-01-24 10:16:08 -05:00 committed by Tim Graham
parent 9d129b72ce
commit 8cdeb8acfc
1 changed files with 27 additions and 0 deletions

View File

@ -149,6 +149,21 @@ class CharFieldTests(TestCase):
), ),
]) ])
def test_non_iterable_choices_two_letters(self):
"""Two letters isn't a valid choice pair."""
class Model(models.Model):
field = models.CharField(max_length=10, choices=['ab'])
field = Model._meta.get_field('field')
self.assertEqual(field.check(), [
Error(
"'choices' must be an iterable containing (actual value, "
"human readable name) tuples.",
obj=field,
id='fields.E005',
),
])
def test_iterable_of_iterable_choices(self): def test_iterable_of_iterable_choices(self):
class ThingItem: class ThingItem:
def __init__(self, value, display): def __init__(self, value, display):
@ -183,6 +198,18 @@ class CharFieldTests(TestCase):
), ),
]) ])
def test_choices_named_group(self):
class Model(models.Model):
field = models.CharField(
max_length=10, choices=[
['knights', [['L', 'Lancelot'], ['G', 'Galahad']]],
['wizards', [['T', 'Tim the Enchanter']]],
['R', 'Random character'],
],
)
self.assertEqual(Model._meta.get_field('field').check(), [])
def test_bad_db_index_value(self): def test_bad_db_index_value(self):
class Model(models.Model): class Model(models.Model):
field = models.CharField(max_length=10, db_index='bad') field = models.CharField(max_length=10, db_index='bad')