diff --git a/tests/constraints/tests.py b/tests/constraints/tests.py index fd68c5156dc..31c5d646523 100644 --- a/tests/constraints/tests.py +++ b/tests/constraints/tests.py @@ -1070,6 +1070,19 @@ class UniqueConstraintTests(TestCase): is_not_null_constraint.validate(Product, Product(price=4, discounted_price=3)) is_not_null_constraint.validate(Product, Product(price=2, discounted_price=1)) + def test_validate_nulls_distinct_fields(self): + Product.objects.create(price=42) + constraint = models.UniqueConstraint( + fields=["price"], + nulls_distinct=False, + name="uniq_prices_nulls_distinct", + ) + constraint.validate(Product, Product(price=None)) + Product.objects.create(price=None) + msg = "Product with this Price already exists." + with self.assertRaisesMessage(ValidationError, msg): + constraint.validate(Product, Product(price=None)) + def test_validate_nulls_distinct_expressions(self): Product.objects.create(price=42) constraint = models.UniqueConstraint( diff --git a/tests/validation/models.py b/tests/validation/models.py index f6b1e0cd620..653be4a239b 100644 --- a/tests/validation/models.py +++ b/tests/validation/models.py @@ -217,17 +217,3 @@ class UniqueConstraintConditionProduct(models.Model): condition=models.Q(color__isnull=True), ), ] - - -class UniqueConstraintNullsDistinctProduct(models.Model): - name = models.CharField(max_length=255, blank=True, null=True) - - class Meta: - required_db_features = {"supports_nulls_distinct_unique_constraints"} - constraints = [ - models.UniqueConstraint( - fields=["name"], - name="name_nulls_not_distinct_uniq", - nulls_distinct=False, - ), - ] diff --git a/tests/validation/test_constraints.py b/tests/validation/test_constraints.py index eea2d0c533c..0b1ee6518e2 100644 --- a/tests/validation/test_constraints.py +++ b/tests/validation/test_constraints.py @@ -6,7 +6,6 @@ from .models import ( ChildUniqueConstraintProduct, Product, UniqueConstraintConditionProduct, - UniqueConstraintNullsDistinctProduct, UniqueConstraintProduct, ) @@ -94,25 +93,3 @@ class PerformConstraintChecksTest(TestCase): UniqueConstraintConditionProduct.objects.create(name="product") product = UniqueConstraintConditionProduct(name="product") product.full_clean(validate_constraints=False) - - @skipUnlessDBFeature("supports_nulls_distinct_unique_constraints") - def test_full_clean_with_nulls_distinct_unique_constraints(self): - UniqueConstraintNullsDistinctProduct.objects.create(name=None) - product = UniqueConstraintNullsDistinctProduct(name=None) - with self.assertRaises(ValidationError) as cm: - product.full_clean() - self.assertEqual( - cm.exception.message_dict, - { - "name": [ - "Unique constraint nulls distinct product with this Name " - "already exists." - ] - }, - ) - - @skipUnlessDBFeature("supports_nulls_distinct_unique_constraints") - def test_full_clean_with_nulls_distinct_unique_constraints_disabled(self): - UniqueConstraintNullsDistinctProduct.objects.create(name=None) - product = UniqueConstraintNullsDistinctProduct(name=None) - product.full_clean(validate_constraints=False)