mirror of
https://github.com/django/django.git
synced 2025-01-22 00:02:15 +00:00
Fixed #34205 -- Fixed Meta.constraints validation crash with ArrayField and __len lookup.
Regression in 88fc9e2826044110b7b22577a227f122fe9c1fb5 that began manifesting in Django 4.1.
This commit is contained in:
parent
b8738aea14
commit
c5ed884eab
1
AUTHORS
1
AUTHORS
@ -431,6 +431,7 @@ answer newbie questions, and generally made Django that much better:
|
||||
james_027@yahoo.com
|
||||
James Aylett
|
||||
James Bennett <james@b-list.org>
|
||||
James Gillard <jamesgillard@live.co.uk>
|
||||
James Murty
|
||||
James Tauber <jtauber@jtauber.com>
|
||||
James Timmins <jameshtimmins@gmail.com>
|
||||
|
@ -297,7 +297,7 @@ class ArrayLenTransform(Transform):
|
||||
return (
|
||||
"CASE WHEN %(lhs)s IS NULL THEN NULL ELSE "
|
||||
"coalesce(array_length(%(lhs)s, 1), 0) END"
|
||||
) % {"lhs": lhs}, params
|
||||
) % {"lhs": lhs}, params * 2
|
||||
|
||||
|
||||
@ArrayField.register_lookup
|
||||
|
@ -9,4 +9,7 @@ Django 4.1.5 fixes several bugs in 4.1.4.
|
||||
Bugfixes
|
||||
========
|
||||
|
||||
* ...
|
||||
* Fixed a long standing bug in the ``__len`` lookup for ``ArrayField`` that
|
||||
caused a crash of model validation on
|
||||
:attr:`Meta.constraints <django.db.models.Options.constraints>`
|
||||
(:ticket:`34205`).
|
||||
|
@ -76,6 +76,16 @@ class SchemaTests(PostgreSQLTestCase):
|
||||
constraint.validate(IntegerArrayModel, IntegerArrayModel())
|
||||
constraint.validate(IntegerArrayModel, IntegerArrayModel(field=[1]))
|
||||
|
||||
def test_check_constraint_array_length(self):
|
||||
constraint = CheckConstraint(
|
||||
check=Q(field__len=1),
|
||||
name="array_length",
|
||||
)
|
||||
msg = f"Constraint “{constraint.name}” is violated."
|
||||
with self.assertRaisesMessage(ValidationError, msg):
|
||||
constraint.validate(IntegerArrayModel, IntegerArrayModel())
|
||||
constraint.validate(IntegerArrayModel, IntegerArrayModel(field=[1]))
|
||||
|
||||
def test_check_constraint_daterange_contains(self):
|
||||
constraint_name = "dates_contains"
|
||||
self.assertNotIn(
|
||||
|
Loading…
x
Reference in New Issue
Block a user