mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #17899 -- Rewrote [Ee]-mail to [Ee]mail
This commit is contained in:
		
				
					committed by
					
						 Claude Paroz
						Claude Paroz
					
				
			
			
				
	
			
			
			
						parent
						
							70a0de37d1
						
					
				
				
					commit
					2c8267bf3d
				
			| @@ -144,7 +144,7 @@ DEFAULT_CHARSET = 'utf-8' | ||||
| # Encoding of files read from disk (template and initial SQL files). | ||||
| FILE_CHARSET = 'utf-8' | ||||
|  | ||||
| # E-mail address that error messages come from. | ||||
| # Email address that error messages come from. | ||||
| SERVER_EMAIL = 'root@localhost' | ||||
|  | ||||
| # Whether to send broken-link emails. | ||||
|   | ||||
| @@ -12,6 +12,6 @@ | ||||
|  | ||||
| {% block content %} | ||||
| <h1>{% trans 'Server Error <em>(500)</em>' %}</h1> | ||||
| <p>{% trans "There's been an error. It's been reported to the site administrators via e-mail and should be fixed shortly. Thanks for your patience." %}</p> | ||||
| <p>{% trans "There's been an error. It's been reported to the site administrators via email and should be fixed shortly. Thanks for your patience." %}</p> | ||||
|  | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -14,6 +14,6 @@ | ||||
|  | ||||
| <h1>{% trans 'Password reset successful' %}</h1> | ||||
|  | ||||
| <p>{% trans "We've e-mailed you instructions for setting your password to the e-mail address you submitted. You should be receiving it shortly." %}</p> | ||||
| <p>{% trans "We've emailed you instructions for setting your password to the email address you submitted. You should be receiving it shortly." %}</p> | ||||
|  | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| {% load i18n %}{% autoescape off %} | ||||
| {% blocktrans %}You're receiving this e-mail because you requested a password reset for your user account at {{ site_name }}.{% endblocktrans %} | ||||
| {% blocktrans %}You're receiving this email because you requested a password reset for your user account at {{ site_name }}.{% endblocktrans %} | ||||
|  | ||||
| {% trans "Please go to the following page and choose a new password:" %} | ||||
| {% block reset_link %} | ||||
|   | ||||
| @@ -14,11 +14,11 @@ | ||||
|  | ||||
| <h1>{% trans "Password reset" %}</h1> | ||||
|  | ||||
| <p>{% trans "Forgotten your password? Enter your e-mail address below, and we'll e-mail instructions for setting a new one." %}</p> | ||||
| <p>{% trans "Forgotten your password? Enter your email address below, and we'll email instructions for setting a new one." %}</p> | ||||
|  | ||||
| <form action="" method="post">{% csrf_token %} | ||||
| {{ form.email.errors }} | ||||
| <p><label for="id_email">{% trans 'E-mail address:' %}</label> {{ form.email }} <input type="submit" value="{% trans 'Reset my password' %}" /></p> | ||||
| <p><label for="id_email">{% trans 'Email address:' %}</label> {{ form.email }} <input type="submit" value="{% trans 'Reset my password' %}" /></p> | ||||
| </form> | ||||
|  | ||||
| {% endblock %} | ||||
|   | ||||
| @@ -193,12 +193,12 @@ class AuthenticationForm(forms.Form): | ||||
|  | ||||
| class PasswordResetForm(forms.Form): | ||||
|     error_messages = { | ||||
|         'unknown': _("That e-mail address doesn't have an associated " | ||||
|         'unknown': _("That email address doesn't have an associated " | ||||
|                      "user account. Are you sure you've registered?"), | ||||
|         'unusable': _("The user account associated with this e-mail " | ||||
|         'unusable': _("The user account associated with this email " | ||||
|                       "address cannot reset the password."), | ||||
|     } | ||||
|     email = forms.EmailField(label=_("E-mail"), max_length=75) | ||||
|     email = forms.EmailField(label=_("Email"), max_length=75) | ||||
|  | ||||
|     def clean_email(self): | ||||
|         """ | ||||
|   | ||||
| @@ -344,4 +344,4 @@ class PasswordResetFormTest(TestCase): | ||||
|         form = PasswordResetForm(data) | ||||
|         self.assertFalse(form.is_valid()) | ||||
|         self.assertEqual(form["email"].errors, | ||||
|                          [_("The user account associated with this e-mail address cannot reset the password.")]) | ||||
|                          [_("The user account associated with this email address cannot reset the password.")]) | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| E-mail sent | ||||
| Email sent | ||||
| @@ -101,7 +101,7 @@ email_re = re.compile( | ||||
|     r'|^"([\001-\010\013\014\016-\037!#-\[\]-\177]|\\[\001-\011\013\014\016-\177])*"' | ||||
|     r')@((?:[A-Z0-9](?:[A-Z0-9-]{0,61}[A-Z0-9])?\.)+[A-Z]{2,6}\.?$)'  # domain | ||||
|     r'|\[(25[0-5]|2[0-4]\d|[0-1]?\d?\d)(\.(25[0-5]|2[0-4]\d|[0-1]?\d?\d)){3}\]$', re.IGNORECASE)  # literal form, ipv4 address (SMTP 4.1.3) | ||||
| validate_email = EmailValidator(email_re, _('Enter a valid e-mail address.'), 'invalid') | ||||
| validate_email = EmailValidator(email_re, _('Enter a valid email address.'), 'invalid') | ||||
|  | ||||
| slug_re = re.compile(r'^[-a-zA-Z0-9_]+$') | ||||
| validate_slug = RegexValidator(slug_re, _("Enter a valid 'slug' consisting of letters, numbers, underscores or hyphens."), 'invalid') | ||||
|   | ||||
| @@ -905,7 +905,7 @@ class DecimalField(Field): | ||||
|  | ||||
| class EmailField(CharField): | ||||
|     default_validators = [validators.validate_email] | ||||
|     description = _("E-mail address") | ||||
|     description = _("Email address") | ||||
|  | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         # max_length should be overridden to 254 characters to be fully | ||||
|   | ||||
| @@ -461,7 +461,7 @@ class RegexField(CharField): | ||||
|  | ||||
| class EmailField(CharField): | ||||
|     default_error_messages = { | ||||
|         'invalid': _('Enter a valid e-mail address.'), | ||||
|         'invalid': _('Enter a valid email address.'), | ||||
|     } | ||||
|     default_validators = [validators.validate_email] | ||||
|  | ||||
|   | ||||
| @@ -241,7 +241,7 @@ applications: | ||||
| * :doc:`Authentication <topics/auth>` | ||||
| * :doc:`Caching <topics/cache>` | ||||
| * :doc:`Logging <topics/logging>` | ||||
| * :doc:`Sending e-mails <topics/email>` | ||||
| * :doc:`Sending emails <topics/email>` | ||||
| * :doc:`Syndication feeds (RSS/Atom) <ref/contrib/syndication>` | ||||
| * :doc:`Comments <ref/contrib/comments/index>`, :doc:`comment moderation <ref/contrib/comments/moderation>` and :doc:`custom comments <ref/contrib/comments/custom>` | ||||
| * :doc:`Pagination <topics/pagination>` | ||||
|   | ||||
| @@ -23,7 +23,7 @@ these changes. | ||||
| * The :mod:`django.contrib.gis.db.backend` module will be removed in favor | ||||
|   of the specific backends. | ||||
|  | ||||
| * ``SMTPConnection`` will be removed in favor of a generic E-mail backend API. | ||||
| * ``SMTPConnection`` will be removed in favor of a generic Email backend API. | ||||
|  | ||||
| * The many to many SQL generation functions on the database backends | ||||
|   will be removed. | ||||
|   | ||||
| @@ -455,7 +455,7 @@ This example illustrates all possible attributes and methods for a | ||||
|  | ||||
|         author_name = 'Sally Smith' # Hard-coded author name. | ||||
|  | ||||
|         # AUTHOR E-MAIL --One of the following three is optional. The framework | ||||
|         # AUTHOR EMAIL --One of the following three is optional. The framework | ||||
|         # looks for them in this order. | ||||
|  | ||||
|         def author_email(self, obj): | ||||
| @@ -635,7 +635,7 @@ This example illustrates all possible attributes and methods for a | ||||
|  | ||||
|         item_author_name = 'Sally Smith' # Hard-coded author name. | ||||
|  | ||||
|         # ITEM AUTHOR E-MAIL --One of the following three is optional. The | ||||
|         # ITEM AUTHOR EMAIL --One of the following three is optional. The | ||||
|         # framework looks for them in this order. | ||||
|         # | ||||
|         # If you specify this, you must specify item_author_name. | ||||
|   | ||||
| @@ -105,7 +105,7 @@ Access the :attr:`~Form.errors` attribute to get a dictionary of error | ||||
| messages:: | ||||
|  | ||||
|     >>> f.errors | ||||
|     {'sender': [u'Enter a valid e-mail address.'], 'subject': [u'This field is required.']} | ||||
|     {'sender': [u'Enter a valid email address.'], 'subject': [u'This field is required.']} | ||||
|  | ||||
| In this dictionary, the keys are the field names, and the values are lists of | ||||
| Unicode strings representing the error messages. The error messages are stored | ||||
| @@ -538,18 +538,18 @@ method you're using:: | ||||
|     >>> print(f.as_table()) | ||||
|     <tr><th>Subject:</th><td><ul class="errorlist"><li>This field is required.</li></ul><input type="text" name="subject" maxlength="100" /></td></tr> | ||||
|     <tr><th>Message:</th><td><input type="text" name="message" value="Hi there" /></td></tr> | ||||
|     <tr><th>Sender:</th><td><ul class="errorlist"><li>Enter a valid e-mail address.</li></ul><input type="text" name="sender" value="invalid email address" /></td></tr> | ||||
|     <tr><th>Sender:</th><td><ul class="errorlist"><li>Enter a valid email address.</li></ul><input type="text" name="sender" value="invalid email address" /></td></tr> | ||||
|     <tr><th>Cc myself:</th><td><input checked="checked" type="checkbox" name="cc_myself" /></td></tr> | ||||
|     >>> print(f.as_ul()) | ||||
|     <li><ul class="errorlist"><li>This field is required.</li></ul>Subject: <input type="text" name="subject" maxlength="100" /></li> | ||||
|     <li>Message: <input type="text" name="message" value="Hi there" /></li> | ||||
|     <li><ul class="errorlist"><li>Enter a valid e-mail address.</li></ul>Sender: <input type="text" name="sender" value="invalid email address" /></li> | ||||
|     <li><ul class="errorlist"><li>Enter a valid email address.</li></ul>Sender: <input type="text" name="sender" value="invalid email address" /></li> | ||||
|     <li>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></li> | ||||
|     >>> print(f.as_p()) | ||||
|     <p><ul class="errorlist"><li>This field is required.</li></ul></p> | ||||
|     <p>Subject: <input type="text" name="subject" maxlength="100" /></p> | ||||
|     <p>Message: <input type="text" name="message" value="Hi there" /></p> | ||||
|     <p><ul class="errorlist"><li>Enter a valid e-mail address.</li></ul></p> | ||||
|     <p><ul class="errorlist"><li>Enter a valid email address.</li></ul></p> | ||||
|     <p>Sender: <input type="text" name="sender" value="invalid email address" /></p> | ||||
|     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> | ||||
|  | ||||
| @@ -572,7 +572,7 @@ pass that in at construction time:: | ||||
|     <div class="errorlist"><div class="error">This field is required.</div></div> | ||||
|     <p>Subject: <input type="text" name="subject" maxlength="100" /></p> | ||||
|     <p>Message: <input type="text" name="message" value="Hi there" /></p> | ||||
|     <div class="errorlist"><div class="error">Enter a valid e-mail address.</div></div> | ||||
|     <div class="errorlist"><div class="error">Enter a valid email address.</div></div> | ||||
|     <p>Sender: <input type="text" name="sender" value="invalid email address" /></p> | ||||
|     <p>Cc myself: <input checked="checked" type="checkbox" name="cc_myself" /></p> | ||||
|  | ||||
|   | ||||
| @@ -28,7 +28,7 @@ exception or returns the clean value:: | ||||
|     >>> f.clean('invalid email address') | ||||
|     Traceback (most recent call last): | ||||
|     ... | ||||
|     ValidationError: [u'Enter a valid e-mail address.'] | ||||
|     ValidationError: [u'Enter a valid email address.'] | ||||
|  | ||||
| Core field arguments | ||||
| -------------------- | ||||
|   | ||||
| @@ -185,7 +185,7 @@ a look at Django's ``EmailField``:: | ||||
|  | ||||
|     class EmailField(CharField): | ||||
|         default_error_messages = { | ||||
|             'invalid': _('Enter a valid e-mail address.'), | ||||
|             'invalid': _('Enter a valid email address.'), | ||||
|         } | ||||
|         default_validators = [validators.validate_email] | ||||
|  | ||||
| @@ -198,7 +198,7 @@ on field definition so:: | ||||
| is equivalent to:: | ||||
|  | ||||
|     email = forms.CharField(validators=[validators.validate_email], | ||||
|             error_messages={'invalid': _('Enter a valid e-mail address.')}) | ||||
|             error_messages={'invalid': _('Enter a valid email address.')}) | ||||
|  | ||||
|  | ||||
| Form field default cleaning | ||||
|   | ||||
| @@ -1622,7 +1622,7 @@ your test suite. | ||||
|     "a@a.com" as a valid email address, but rejects "aaa" with a reasonable | ||||
|     error message:: | ||||
|  | ||||
|         self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': [u'Enter a valid e-mail address.']}) | ||||
|         self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': [u'Enter a valid email address.']}) | ||||
|  | ||||
|  | ||||
| .. method:: TestCase.assertContains(response, text, count=None, status_code=200, msg_prefix='', html=False) | ||||
|   | ||||
| @@ -215,7 +215,7 @@ class ClientTest(TestCase): | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|         self.assertTemplateUsed(response, "Invalid POST Template") | ||||
|  | ||||
|         self.assertFormError(response, 'form', 'email', 'Enter a valid e-mail address.') | ||||
|         self.assertFormError(response, 'form', 'email', 'Enter a valid email address.') | ||||
|  | ||||
|     def test_valid_form_with_template(self): | ||||
|         "POST valid data to a form using multiple templates" | ||||
| @@ -263,7 +263,7 @@ class ClientTest(TestCase): | ||||
|         self.assertTemplateUsed(response, 'base.html') | ||||
|         self.assertTemplateNotUsed(response, "Invalid POST Template") | ||||
|  | ||||
|         self.assertFormError(response, 'form', 'email', 'Enter a valid e-mail address.') | ||||
|         self.assertFormError(response, 'form', 'email', 'Enter a valid email address.') | ||||
|  | ||||
|     def test_unknown_page(self): | ||||
|         "GET an invalid URL" | ||||
|   | ||||
| @@ -897,7 +897,7 @@ class AdminViewPermissionsTest(TestCase): | ||||
|         self.assertFalse(login.context) | ||||
|         self.client.get('/test_admin/admin/logout/') | ||||
|  | ||||
|         # Test if user enters e-mail address | ||||
|         # Test if user enters email address | ||||
|         response = self.client.get('/test_admin/admin/') | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|         login = self.client.post('/test_admin/admin/', self.super_email_login) | ||||
| @@ -907,7 +907,7 @@ class AdminViewPermissionsTest(TestCase): | ||||
|         self.assertContains(login, ERROR_MESSAGE) | ||||
|         new_user = User(username='jondoe', password='secret', email='super@example.com') | ||||
|         new_user.save() | ||||
|         # check to ensure if there are multiple e-mail addresses a user doesn't get a 500 | ||||
|         # check to ensure if there are multiple email addresses a user doesn't get a 500 | ||||
|         login = self.client.post('/test_admin/admin/', self.super_email_login) | ||||
|         self.assertContains(login, ERROR_MESSAGE) | ||||
|  | ||||
| @@ -1556,7 +1556,7 @@ class SecureViewTests(TestCase): | ||||
|         # make sure the view removes test cookie | ||||
|         self.assertEqual(self.client.session.test_cookie_worked(), False) | ||||
|  | ||||
|         # Test if user enters e-mail address | ||||
|         # Test if user enters email address | ||||
|         response = self.client.get('/test_admin/admin/secure-view/') | ||||
|         self.assertEqual(response.status_code, 200) | ||||
|         login = self.client.post('/test_admin/admin/secure-view/', self.super_email_login) | ||||
| @@ -1566,7 +1566,7 @@ class SecureViewTests(TestCase): | ||||
|         self.assertContains(login, ERROR_MESSAGE) | ||||
|         new_user = User(username='jondoe', password='secret', email='super@example.com') | ||||
|         new_user.save() | ||||
|         # check to ensure if there are multiple e-mail addresses a user doesn't get a 500 | ||||
|         # check to ensure if there are multiple email addresses a user doesn't get a 500 | ||||
|         login = self.client.post('/test_admin/admin/secure-view/', self.super_email_login) | ||||
|         self.assertContains(login, ERROR_MESSAGE) | ||||
|  | ||||
|   | ||||
| @@ -613,7 +613,7 @@ class FormsExtraTestCase(TestCase, AssertFormErrorsMixin): | ||||
|         data = dict(email='invalid') | ||||
|         f = CommentForm(data, auto_id=False, error_class=DivErrorList) | ||||
|         self.assertHTMLEqual(f.as_p(), """<p>Name: <input type="text" name="name" maxlength="50" /></p> | ||||
| <div class="errorlist"><div class="error">Enter a valid e-mail address.</div></div> | ||||
| <div class="errorlist"><div class="error">Enter a valid email address.</div></div> | ||||
| <p>Email: <input type="text" name="email" value="invalid" /></p> | ||||
| <div class="errorlist"><div class="error">This field is required.</div></div> | ||||
| <p>Comment: <input type="text" name="comment" /></p>""") | ||||
|   | ||||
| @@ -507,16 +507,16 @@ class FieldsTests(SimpleTestCase): | ||||
|         self.assertRaisesMessage(ValidationError, "'This field is required.'", f.clean, '') | ||||
|         self.assertRaisesMessage(ValidationError, "'This field is required.'", f.clean, None) | ||||
|         self.assertEqual('person@example.com', f.clean('person@example.com')) | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo@') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo@bar') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'example@invalid-.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'example@-invalid.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'example@inv-.alid-.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'example@inv-.-alid.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo@') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo@bar') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'example@invalid-.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'example@-invalid.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'example@inv-.alid-.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'example@inv-.-alid.com') | ||||
|         self.assertEqual('example@valid-----hyphens.com', f.clean('example@valid-----hyphens.com')) | ||||
|         self.assertEqual('example@valid-with-hyphens.com', f.clean('example@valid-with-hyphens.com')) | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'example@.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'example@.com') | ||||
|         self.assertEqual('local@domain.with.idn.xyz\xe4\xf6\xfc\xdfabc.part.com', f.clean('local@domain.with.idn.xyzäöüßabc.part.com')) | ||||
|  | ||||
|     def test_email_regexp_for_performance(self): | ||||
| @@ -525,7 +525,7 @@ class FieldsTests(SimpleTestCase): | ||||
|         # if the security fix isn't in place. | ||||
|         self.assertRaisesMessage( | ||||
|                 ValidationError, | ||||
|                 "'Enter a valid e-mail address.'", | ||||
|                 "'Enter a valid email address.'", | ||||
|                 f.clean, | ||||
|                 'viewx3dtextx26qx3d@yahoo.comx26latlngx3d15854521645943074058' | ||||
|             ) | ||||
| @@ -536,9 +536,9 @@ class FieldsTests(SimpleTestCase): | ||||
|         self.assertEqual('', f.clean(None)) | ||||
|         self.assertEqual('person@example.com', f.clean('person@example.com')) | ||||
|         self.assertEqual('example@example.com', f.clean('      example@example.com  \t   \t ')) | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo@') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'foo@bar') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo@') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'foo@bar') | ||||
|  | ||||
|     def test_emailfield_3(self): | ||||
|         f = EmailField(min_length=10, max_length=15) | ||||
| @@ -926,7 +926,7 @@ class FieldsTests(SimpleTestCase): | ||||
|         f = ComboField(fields=[CharField(max_length=20), EmailField()]) | ||||
|         self.assertEqual('test@example.com', f.clean('test@example.com')) | ||||
|         self.assertRaisesMessage(ValidationError, "'Ensure this value has at most 20 characters (it has 28).'", f.clean, 'longemailaddress@example.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'not an e-mail') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'not an email') | ||||
|         self.assertRaisesMessage(ValidationError, "'This field is required.'", f.clean, '') | ||||
|         self.assertRaisesMessage(ValidationError, "'This field is required.'", f.clean, None) | ||||
|  | ||||
| @@ -934,7 +934,7 @@ class FieldsTests(SimpleTestCase): | ||||
|         f = ComboField(fields=[CharField(max_length=20), EmailField()], required=False) | ||||
|         self.assertEqual('test@example.com', f.clean('test@example.com')) | ||||
|         self.assertRaisesMessage(ValidationError, "'Ensure this value has at most 20 characters (it has 28).'", f.clean, 'longemailaddress@example.com') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid e-mail address.'", f.clean, 'not an e-mail') | ||||
|         self.assertRaisesMessage(ValidationError, "'Enter a valid email address.'", f.clean, 'not an email') | ||||
|         self.assertEqual('', f.clean('')) | ||||
|         self.assertEqual('', f.clean(None)) | ||||
|  | ||||
|   | ||||
| @@ -499,11 +499,11 @@ class AssertFormErrorTests(TestCase): | ||||
|         try: | ||||
|             self.assertFormError(response, 'form', 'email', 'Some error.') | ||||
|         except AssertionError as e: | ||||
|             self.assertIn(str_prefix("The field 'email' on form 'form' in context 0 does not contain the error 'Some error.' (actual errors: [%(_)s'Enter a valid e-mail address.'])"), str(e)) | ||||
|             self.assertIn(str_prefix("The field 'email' on form 'form' in context 0 does not contain the error 'Some error.' (actual errors: [%(_)s'Enter a valid email address.'])"), str(e)) | ||||
|         try: | ||||
|             self.assertFormError(response, 'form', 'email', 'Some error.', msg_prefix='abc') | ||||
|         except AssertionError as e: | ||||
|             self.assertIn(str_prefix("abc: The field 'email' on form 'form' in context 0 does not contain the error 'Some error.' (actual errors: [%(_)s'Enter a valid e-mail address.'])"), str(e)) | ||||
|             self.assertIn(str_prefix("abc: The field 'email' on form 'form' in context 0 does not contain the error 'Some error.' (actual errors: [%(_)s'Enter a valid email address.'])"), str(e)) | ||||
|  | ||||
|     def test_unknown_nonfield_error(self): | ||||
|         """ | ||||
|   | ||||
| @@ -476,7 +476,7 @@ class AssertRaisesMsgTest(SimpleTestCase): | ||||
| class AssertFieldOutputTests(SimpleTestCase): | ||||
|  | ||||
|     def test_assert_field_output(self): | ||||
|         error_invalid = ['Enter a valid e-mail address.'] | ||||
|         error_invalid = ['Enter a valid email address.'] | ||||
|         self.assertFieldOutput(EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid}) | ||||
|         self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'a@a.com'}, {'aaa': error_invalid + ['Another error']}) | ||||
|         self.assertRaises(AssertionError, self.assertFieldOutput, EmailField, {'a@a.com': 'Wrong output'}, {'aaa': error_invalid}) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user