From 8a7d407cf70b8e1e2d0c35acaa157a9f765d16e7 Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Tue, 31 Dec 2024 21:17:07 -0500 Subject: [PATCH] add test for warnings --- tests/model_fields_/test_arrayfield.py | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/tests/model_fields_/test_arrayfield.py b/tests/model_fields_/test_arrayfield.py index d06b5b27..4e11c557 100644 --- a/tests/model_fields_/test_arrayfield.py +++ b/tests/model_fields_/test_arrayfield.py @@ -506,7 +506,7 @@ def test_exact_tags(self): @isolate_apps("model_fields_") class CheckTests(SimpleTestCase): - def test_field_checks(self): + def test_base_field_errors(self): class MyModel(models.Model): field = ArrayField(models.CharField(max_length=-1)) @@ -515,7 +515,25 @@ class MyModel(models.Model): self.assertEqual(len(errors), 1) # The inner CharField has a non-positive max_length. self.assertEqual(errors[0].id, "django_mongodb.array.E001") - self.assertIn("max_length", errors[0].msg) + msg = errors[0].msg + self.assertIn("Base field for array has errors:", msg) + self.assertIn("'max_length' must be a positive integer. (fields.E121)", msg) + + def test_base_field_warnings(self): + class WarningField(models.IntegerField): + def check(self): + return [checks.Warning("Test warning", obj=self, id="test.E001")] + + class MyModel(models.Model): + field = ArrayField(WarningField(), default=None) + + model = MyModel() + errors = model.check() + self.assertEqual(len(errors), 1) + self.assertEqual(errors[0].id, "django_mongodb.array.W004") + msg = errors[0].msg + self.assertIn("Base field for array has warnings:", msg) + self.assertIn("Test warning (test.E001)", msg) def test_invalid_base_fields(self): class MyModel(models.Model):