diff options
| author | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2020-10-14 13:09:24 +0200 |
|---|---|---|
| committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2020-10-14 20:56:04 +0200 |
| commit | ee0abac169c2dcc6818d583247903c2a8ef55f7c (patch) | |
| tree | 4c9486072a021b465a9c10039e395fc6c3de2d61 /tests/postgres_tests | |
| parent | bbd55e58639c33b4c5adff5f41b78deffc915c11 (diff) | |
Refs #32096 -- Fixed ExclusionConstraint crash with JSONField key transforms in expressions.
Regression in 6789ded0a6ab797f0dcdfa6ad5d1cfa46e23abcd.
Diffstat (limited to 'tests/postgres_tests')
| -rw-r--r-- | tests/postgres_tests/migrations/0002_create_test_models.py | 1 | ||||
| -rw-r--r-- | tests/postgres_tests/models.py | 1 | ||||
| -rw-r--r-- | tests/postgres_tests/test_constraints.py | 17 |
3 files changed, 19 insertions, 0 deletions
diff --git a/tests/postgres_tests/migrations/0002_create_test_models.py b/tests/postgres_tests/migrations/0002_create_test_models.py index e334057d22..cd8b20ae01 100644 --- a/tests/postgres_tests/migrations/0002_create_test_models.py +++ b/tests/postgres_tests/migrations/0002_create_test_models.py @@ -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', diff --git a/tests/postgres_tests/models.py b/tests/postgres_tests/models.py index a5bfc72fe7..56c81064f3 100644 --- a/tests/postgres_tests/models.py +++ b/tests/postgres_tests/models.py @@ -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) diff --git a/tests/postgres_tests/test_constraints.py b/tests/postgres_tests/test_constraints.py index 89463650e8..8621d7a052 100644 --- a/tests/postgres_tests/test_constraints.py +++ b/tests/postgres_tests/test_constraints.py @@ -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)) |
