mirror of
				https://github.com/django/django.git
				synced 2025-10-31 01:25:32 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			134 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from unittest import TestCase
 | |
| 
 | |
| from django.core.exceptions import ValidationError
 | |
| from django.db import models
 | |
| 
 | |
| 
 | |
| class ValidationMessagesTest(TestCase):
 | |
|     def _test_validation_messages(self, field, value, expected):
 | |
|         with self.assertRaises(ValidationError) as cm:
 | |
|             field.clean(value, None)
 | |
|         self.assertEqual(cm.exception.messages, expected)
 | |
| 
 | |
|     def test_autofield_field_raises_error_message(self):
 | |
|         f = models.AutoField(primary_key=True)
 | |
|         self._test_validation_messages(f, "fõo", ["“fõo” value must be an integer."])
 | |
| 
 | |
|     def test_integer_field_raises_error_message(self):
 | |
|         f = models.IntegerField()
 | |
|         self._test_validation_messages(f, "fõo", ["“fõo” value must be an integer."])
 | |
| 
 | |
|     def test_boolean_field_raises_error_message(self):
 | |
|         f = models.BooleanField()
 | |
|         self._test_validation_messages(
 | |
|             f, "fõo", ["“fõo” value must be either True or False."]
 | |
|         )
 | |
| 
 | |
|     def test_nullable_boolean_field_raises_error_message(self):
 | |
|         f = models.BooleanField(null=True)
 | |
|         self._test_validation_messages(
 | |
|             f, "fõo", ["“fõo” value must be either True, False, or None."]
 | |
|         )
 | |
| 
 | |
|     def test_float_field_raises_error_message(self):
 | |
|         f = models.FloatField()
 | |
|         self._test_validation_messages(f, "fõo", ["“fõo” value must be a float."])
 | |
| 
 | |
|     def test_decimal_field_raises_error_message(self):
 | |
|         f = models.DecimalField()
 | |
|         self._test_validation_messages(
 | |
|             f, "fõo", ["“fõo” value must be a decimal number."]
 | |
|         )
 | |
| 
 | |
|     def test_null_boolean_field_raises_error_message(self):
 | |
|         f = models.BooleanField(null=True)
 | |
|         self._test_validation_messages(
 | |
|             f, "fõo", ["“fõo” value must be either True, False, or None."]
 | |
|         )
 | |
| 
 | |
|     def test_date_field_raises_error_message(self):
 | |
|         f = models.DateField()
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "fõo",
 | |
|             [
 | |
|                 "“fõo” value has an invalid date format. It must be in YYYY-MM-DD "
 | |
|                 "format."
 | |
|             ],
 | |
|         )
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "aaaa-10-10",
 | |
|             [
 | |
|                 "“aaaa-10-10” value has an invalid date format. It must be in "
 | |
|                 "YYYY-MM-DD format."
 | |
|             ],
 | |
|         )
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "2011-13-10",
 | |
|             [
 | |
|                 "“2011-13-10” value has the correct format (YYYY-MM-DD) but it is an "
 | |
|                 "invalid date."
 | |
|             ],
 | |
|         )
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "2011-10-32",
 | |
|             [
 | |
|                 "“2011-10-32” value has the correct format (YYYY-MM-DD) but it is an "
 | |
|                 "invalid date."
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_datetime_field_raises_error_message(self):
 | |
|         f = models.DateTimeField()
 | |
|         # Wrong format
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "fõo",
 | |
|             [
 | |
|                 "“fõo” value has an invalid format. It must be in "
 | |
|                 "YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] format."
 | |
|             ],
 | |
|         )
 | |
|         # Correct format but invalid date
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "2011-10-32",
 | |
|             [
 | |
|                 "“2011-10-32” value has the correct format (YYYY-MM-DD) but it is an "
 | |
|                 "invalid date."
 | |
|             ],
 | |
|         )
 | |
|         # Correct format but invalid date/time
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "2011-10-32 10:10",
 | |
|             [
 | |
|                 "“2011-10-32 10:10” value has the correct format "
 | |
|                 "(YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]) but it is an invalid date/time."
 | |
|             ],
 | |
|         )
 | |
| 
 | |
|     def test_time_field_raises_error_message(self):
 | |
|         f = models.TimeField()
 | |
|         # Wrong format
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "fõo",
 | |
|             [
 | |
|                 "“fõo” value has an invalid format. It must be in HH:MM[:ss[.uuuuuu]] "
 | |
|                 "format."
 | |
|             ],
 | |
|         )
 | |
|         # Correct format but invalid time
 | |
|         self._test_validation_messages(
 | |
|             f,
 | |
|             "25:50",
 | |
|             [
 | |
|                 "“25:50” value has the correct format (HH:MM[:ss[.uuuuuu]]) but it is "
 | |
|                 "an invalid time."
 | |
|             ],
 | |
|         )
 |