summaryrefslogtreecommitdiff
path: root/tests/test_utils
diff options
context:
space:
mode:
authorBaptiste Mispelon <bmispelon@gmail.com>2022-02-14 11:02:33 +0100
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2022-02-15 07:15:44 +0100
commitd84cd91e90cb0871e43f98cba8c53be99053e903 (patch)
tree2e8337022d486161d796554b73642c08de527d6c /tests/test_utils
parent9bb13def5d416ff3d5d1928a2def5babac0e19f6 (diff)
Refs #33348 -- Improved messages raised by SimpleTestCase.assertFormError()/assertFormsetErrors().
This makes messages use BaseFormSet/BaseForm.__repr__() instead of context, and adds the _assert_form_error() helper.
Diffstat (limited to 'tests/test_utils')
-rw-r--r--tests/test_utils/tests.py130
1 files changed, 53 insertions, 77 deletions
diff --git a/tests/test_utils/tests.py b/tests/test_utils/tests.py
index 038e79732b..506773b712 100644
--- a/tests/test_utils/tests.py
+++ b/tests/test_utils/tests.py
@@ -1404,46 +1404,33 @@ class AssertFormErrorTests(SimpleTestCase):
self.assertFormError(response, "form", "field", "invalid value")
def test_field_not_in_form(self):
- msg = "The form 'form' in context 0 does not contain the field 'other_field'"
+ msg = (
+ "The form <TestForm bound=True, valid=False, fields=(field)> does not "
+ "contain the field 'other_field'."
+ )
response = mock.Mock(context=[{"form": TestForm.invalid()}])
with self.assertRaisesMessage(AssertionError, msg):
self.assertFormError(response, "form", "other_field", "invalid value")
- def test_field_not_in_form_multicontext(self):
- msg = "The form 'form' in context 1 does not contain the field 'other_field'"
- response = mock.Mock(context=[{}, {"form": TestForm.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormError(response, "form", "other_field", "invalid value")
-
def test_field_with_no_errors(self):
- msg = "The field 'field' on form 'form' in context 0 contains no errors"
+ msg = (
+ "The errors of field 'field' on form <TestForm bound=True, valid=True, "
+ "fields=(field)> don't match."
+ )
response = mock.Mock(context=[{"form": TestForm.valid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormError(response, "form", "field", "invalid value")
-
- def test_field_with_no_errors_multicontext(self):
- msg = "The field 'field' on form 'form' in context 1 contains no errors"
- response = mock.Mock(context=[{}, {"form": TestForm.valid()}])
- with self.assertRaisesMessage(AssertionError, msg):
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
self.assertFormError(response, "form", "field", "invalid value")
+ self.assertIn("[] != ['invalid value']", str(ctx.exception))
def test_field_with_different_error(self):
msg = (
- "The field 'field' on form 'form' in context 0 does not contain "
- "the error 'other error' (actual errors: ['invalid value'])"
+ "The errors of field 'field' on form <TestForm bound=True, valid=False, "
+ "fields=(field)> don't match."
)
response = mock.Mock(context=[{"form": TestForm.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormError(response, "form", "field", "other error")
-
- def test_field_with_different_error_multicontext(self):
- msg = (
- "The field 'field' on form 'form' in context 1 does not contain "
- "the error 'other error' (actual errors: ['invalid value'])"
- )
- response = mock.Mock(context=[{}, {"form": TestForm.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
self.assertFormError(response, "form", "field", "other error")
+ self.assertIn("['invalid value'] != ['other error']", str(ctx.exception))
def test_basic_positive_assertion(self):
response = mock.Mock(context=[{"form": TestForm.invalid()}])
@@ -1467,8 +1454,14 @@ class AssertFormErrorTests(SimpleTestCase):
self.assertFormError(response, "form", "field", [])
def test_empty_errors_invalid_form(self):
+ msg = (
+ "The errors of field 'field' on form <TestForm bound=True, valid=False, "
+ "fields=(field)> don't match."
+ )
response = mock.Mock(context=[{"form": TestForm.invalid()}])
- self.assertFormError(response, "form", "field", [])
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
+ self.assertFormError(response, "form", "field", [])
+ self.assertIn("['invalid value'] != []", str(ctx.exception))
def test_non_field_errors(self):
response = mock.Mock(context=[{"form": TestForm.invalid(nonfield=True)}])
@@ -1476,17 +1469,22 @@ class AssertFormErrorTests(SimpleTestCase):
@ignore_warnings(category=RemovedInDjango50Warning)
def test_errors_none(self):
+ msg = (
+ "The errors of field 'field' on form <TestForm bound=True, valid=False, "
+ "fields=(field)> don't match."
+ )
response = mock.Mock(context=[{"form": TestForm.invalid()}])
- self.assertFormError(response, "form", "field", None)
+ with self.assertRaisesMessage(AssertionError, msg):
+ self.assertFormError(response, "form", "field", None)
def test_errors_none_warning(self):
- response = mock.Mock(context=[{"form": TestForm.invalid()}])
+ response = mock.Mock(context=[{"form": TestForm.valid()}])
msg = (
"Passing errors=None to assertFormError() is deprecated, use "
"errors=[] instead."
)
with self.assertWarnsMessage(RemovedInDjango50Warning, msg):
- self.assertFormError(response, "form", "value", None)
+ self.assertFormError(response, "form", "field", None)
class AssertFormsetErrorTests(SimpleTestCase):
@@ -1520,8 +1518,8 @@ class AssertFormsetErrorTests(SimpleTestCase):
def test_field_not_in_form(self):
msg = (
- "The formset 'formset', form 0 in context 0 does not contain the "
- "field 'other_field'"
+ "The form 0 of formset <TestFormset: bound=True valid=False total_forms=1> "
+ "does not contain the field 'other_field'."
)
response = mock.Mock(context=[{"formset": TestFormset.invalid()}])
with self.assertRaisesMessage(AssertionError, msg):
@@ -1533,58 +1531,25 @@ class AssertFormsetErrorTests(SimpleTestCase):
"invalid value",
)
- def test_field_not_in_form_multicontext(self):
- msg = (
- "The formset 'formset', form 0 in context 1 does not contain the "
- "field 'other_field'"
- )
- response = mock.Mock(context=[{}, {"formset": TestFormset.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(
- response,
- "formset",
- 0,
- "other_field",
- "invalid value",
- )
-
def test_field_with_no_errors(self):
msg = (
- "The field 'field' on formset 'formset', form 0 in context 0 "
- "contains no errors"
+ "The errors of field 'field' on form 0 of formset <TestFormset: bound=True "
+ "valid=True total_forms=1> don't match."
)
response = mock.Mock(context=[{"formset": TestFormset.valid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(response, "formset", 0, "field", "invalid value")
-
- def test_field_with_no_errors_multicontext(self):
- msg = (
- "The field 'field' on formset 'formset', form 0 in context 1 "
- "contains no errors"
- )
- response = mock.Mock(context=[{}, {"formset": TestFormset.valid()}])
- with self.assertRaisesMessage(AssertionError, msg):
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
self.assertFormsetError(response, "formset", 0, "field", "invalid value")
+ self.assertIn("[] != ['invalid value']", str(ctx.exception))
def test_field_with_different_error(self):
msg = (
- "The field 'field' on formset 'formset', form 0 in context 0 does"
- " not contain the error 'other error' (actual errors: ['invalid "
- "value'])"
+ "The errors of field 'field' on form 0 of formset <TestFormset: bound=True "
+ "valid=False total_forms=1> don't match."
)
response = mock.Mock(context=[{"formset": TestFormset.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
- self.assertFormsetError(response, "formset", 0, "field", "other error")
-
- def test_field_with_different_error_multicontext(self):
- msg = (
- "The field 'field' on formset 'formset', form 0 in context 1 does"
- " not contain the error 'other error' (actual errors: ['invalid "
- "value'])"
- )
- response = mock.Mock(context=[{}, {"formset": TestFormset.invalid()}])
- with self.assertRaisesMessage(AssertionError, msg):
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
self.assertFormsetError(response, "formset", 0, "field", "other error")
+ self.assertIn("['invalid value'] != ['other error']", str(ctx.exception))
def test_basic_positive_assertion(self):
response = mock.Mock(context=[{"formset": TestFormset.invalid()}])
@@ -1608,8 +1573,14 @@ class AssertFormsetErrorTests(SimpleTestCase):
self.assertFormsetError(response, "formset", 0, "field", [])
def test_empty_errors_invalid_formset(self):
+ msg = (
+ "The errors of field 'field' on form 0 of formset <TestFormset: bound=True "
+ "valid=False total_forms=1> don't match."
+ )
response = mock.Mock(context=[{}, {"formset": TestFormset.invalid()}])
- self.assertFormsetError(response, "formset", 0, "field", [])
+ with self.assertRaisesMessage(AssertionError, msg) as ctx:
+ self.assertFormsetError(response, "formset", 0, "field", [])
+ self.assertIn("['invalid value'] != []", str(ctx.exception))
def test_non_field_errors(self):
response = mock.Mock(
@@ -1670,11 +1641,16 @@ class AssertFormsetErrorTests(SimpleTestCase):
@ignore_warnings(category=RemovedInDjango50Warning)
def test_errors_none(self):
+ msg = (
+ "The errors of field 'field' on form 0 of formset <TestFormset: bound=True "
+ "valid=False total_forms=1> don't match."
+ )
response = mock.Mock(context=[{"formset": TestFormset.invalid()}])
- self.assertFormsetError(response, "formset", 0, "field", None)
+ with self.assertRaisesMessage(AssertionError, msg):
+ self.assertFormsetError(response, "formset", 0, "field", None)
def test_errors_none_warning(self):
- response = mock.Mock(context=[{"formset": TestFormset.invalid()}])
+ response = mock.Mock(context=[{"formset": TestFormset.valid()}])
msg = (
"Passing errors=None to assertFormsetError() is deprecated, use "
"errors=[] instead."