summaryrefslogtreecommitdiff
path: root/tests/constraints
diff options
context:
space:
mode:
authorSimon Charette <charette.s@gmail.com>2024-07-13 22:09:50 -0400
committerSarah Boyce <42296566+sarahboyce@users.noreply.github.com>2024-07-17 12:52:17 +0200
commit13922580cccfb9ab2922ff4943dd39da56dfbd8c (patch)
tree93e235ee34aa2afb4d17d3e0c9624877ee5a8f34 /tests/constraints
parent5dc17177c38662d6f4408258ee117cd80e0cb933 (diff)
Refs #30581 -- Made unattached UniqueConstraint(fields) validation testable.
The logic allowing UniqueConstraint(fields).validate to preserve backward compatiblity with Model.unique_error_message failed to account for cases where the constraint might not be attached to a model which is a common pattern during testing. This changes allows for arbitrary UniqueConstraint(fields) to be tested in isolation without requiring actual models backing them up. Co-authored-by: Mark G <mark.gensler@protonmail.com>
Diffstat (limited to 'tests/constraints')
-rw-r--r--tests/constraints/tests.py9
1 files changed, 8 insertions, 1 deletions
diff --git a/tests/constraints/tests.py b/tests/constraints/tests.py
index 86efaa79e7..8b7599adc1 100644
--- a/tests/constraints/tests.py
+++ b/tests/constraints/tests.py
@@ -896,6 +896,13 @@ class UniqueConstraintTests(TestCase):
ChildUniqueConstraintProduct(name=self.p1.name, color=self.p1.color),
)
+ def test_validate_fields_unattached(self):
+ Product.objects.create(price=42)
+ constraint = models.UniqueConstraint(fields=["price"], name="uniq_prices")
+ msg = "Product with this Price already exists."
+ with self.assertRaisesMessage(ValidationError, msg):
+ constraint.validate(Product, Product(price=42))
+
@skipUnlessDBFeature("supports_partial_indexes")
def test_validate_condition(self):
p1 = UniqueConstraintConditionProduct.objects.create(name="p1")
@@ -921,7 +928,7 @@ class UniqueConstraintTests(TestCase):
)
@skipUnlessDBFeature("supports_partial_indexes")
- def test_validate_conditon_custom_error(self):
+ def test_validate_condition_custom_error(self):
p1 = UniqueConstraintConditionProduct.objects.create(name="p1")
constraint = models.UniqueConstraint(
fields=["name"],