mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Refs #32096 -- Fixed ExclusionConstraint crash with JSONField key transforms in expressions.
Regression in 6789ded0a6
.
This commit is contained in:
@@ -303,6 +303,7 @@ class Migration(migrations.Migration):
|
||||
('start', models.DateTimeField()),
|
||||
('end', models.DateTimeField()),
|
||||
('cancelled', models.BooleanField(default=False)),
|
||||
('requirements', models.JSONField(blank=True, null=True)),
|
||||
],
|
||||
options={
|
||||
'required_db_vendor': 'postgresql',
|
||||
|
@@ -191,3 +191,4 @@ class HotelReservation(PostgreSQLModel):
|
||||
start = models.DateTimeField()
|
||||
end = models.DateTimeField()
|
||||
cancelled = models.BooleanField(default=False)
|
||||
requirements = models.JSONField(blank=True, null=True)
|
||||
|
@@ -7,6 +7,7 @@ from django.db import (
|
||||
from django.db.models import (
|
||||
CheckConstraint, Deferrable, F, Func, Q, UniqueConstraint,
|
||||
)
|
||||
from django.db.models.fields.json import KeyTextTransform
|
||||
from django.db.models.functions import Left
|
||||
from django.test import skipUnlessDBFeature
|
||||
from django.utils import timezone
|
||||
@@ -620,6 +621,22 @@ class ExclusionConstraintTests(PostgreSQLTestCase):
|
||||
editor.add_constraint(Scene, constraint)
|
||||
self.assertIn(constraint_name, self.get_constraints(Scene._meta.db_table))
|
||||
|
||||
def test_expressions_with_key_transform(self):
|
||||
constraint_name = 'exclude_overlapping_reservations_smoking'
|
||||
constraint = ExclusionConstraint(
|
||||
name=constraint_name,
|
||||
expressions=[
|
||||
(F('datespan'), RangeOperators.OVERLAPS),
|
||||
(KeyTextTransform('smoking', 'requirements'), RangeOperators.EQUAL),
|
||||
],
|
||||
)
|
||||
with connection.schema_editor() as editor:
|
||||
editor.add_constraint(HotelReservation, constraint)
|
||||
self.assertIn(
|
||||
constraint_name,
|
||||
self.get_constraints(HotelReservation._meta.db_table),
|
||||
)
|
||||
|
||||
def test_range_adjacent_initially_deferred(self):
|
||||
constraint_name = 'ints_adjacent_deferred'
|
||||
self.assertNotIn(constraint_name, self.get_constraints(RangesModel._meta.db_table))
|
||||
|
Reference in New Issue
Block a user