mirror of
https://github.com/django/django.git
synced 2025-01-13 11:57:01 +00:00
c471d471bf
When reporting a validation error (during model validation or fixture loading, for example), the error messages now report the bad value as well as the expected type. This can make identifying the offending field and problem a bit easier. Fixed #11595. Patch from raulcd and wildfire with supervision from Russell. git-svn-id: http://code.djangoproject.com/svn/django/trunk@16638 bcc190cf-cafb-0310-a4f2-bffc1f526a37
58 lines
2.1 KiB
Python
58 lines
2.1 KiB
Python
from django.core.exceptions import ValidationError
|
|
from django.utils.unittest import TestCase
|
|
from django.db import models
|
|
|
|
|
|
class ValidationMessagesTest(TestCase):
|
|
|
|
def test_autofield_field_raises_error_message(self):
|
|
f = models.AutoField(primary_key=True)
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages, [u"'foo' value must be an integer."])
|
|
|
|
def test_integer_field_raises_error_message(self):
|
|
f = models.IntegerField()
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages, [u"'foo' value must be an integer."])
|
|
|
|
def test_boolean_field_raises_error_message(self):
|
|
f = models.BooleanField()
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages,
|
|
[u"'foo' value must be either True or False."])
|
|
|
|
def test_float_field_raises_error_message(self):
|
|
f = models.FloatField()
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages, [u"'foo' value must be a float."])
|
|
|
|
def test_decimal_field_raises_error_message(self):
|
|
f = models.DecimalField()
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages,
|
|
[u"'foo' value must be a decimal number."])
|
|
|
|
def test_null_boolean_field_raises_error_message(self):
|
|
f = models.NullBooleanField()
|
|
self.assertRaises(ValidationError, f.clean, 'foo', None)
|
|
try:
|
|
f.clean('foo', None)
|
|
except ValidationError, e:
|
|
self.assertEqual(e.messages,
|
|
[u"'foo' value must be either None, True or False."])
|