diff options
| author | Simon Charette <charette.s@gmail.com> | 2024-04-02 16:33:31 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-04-02 17:33:31 -0300 |
| commit | 888b9042b3598bab6557c62de82505eec9ea62ed (patch) | |
| tree | 8c1acbee4041c8fbedd487b77a4d5ebd36104ee9 /tests | |
| parent | 5f180216409d75290478c71ddb0ff8a68c91dc16 (diff) | |
Fixed #35336 -- Addressed crash when adding a GeneratedField with % literals.
A longer term solution is likely to have a better separation of parametrized
DDL altogether to handle checks, constraints, defaults, and generated fields
but such a change would require a significant refactor that isn't suitable
for a backport.
Thanks Adrian Garcia for the report.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/schema/tests.py | 44 |
1 files changed, 43 insertions, 1 deletions
diff --git a/tests/schema/tests.py b/tests/schema/tests.py index f8e314d270..86ac7382cc 100644 --- a/tests/schema/tests.py +++ b/tests/schema/tests.py @@ -54,7 +54,16 @@ from django.db.models import ( Value, ) from django.db.models.fields.json import KT, KeyTextTransform -from django.db.models.functions import Abs, Cast, Collate, Lower, Random, Round, Upper +from django.db.models.functions import ( + Abs, + Cast, + Collate, + Concat, + Lower, + Random, + Round, + Upper, +) from django.db.models.indexes import IndexExpression from django.db.transaction import TransactionManagementError, atomic from django.test import TransactionTestCase, skipIfDBFeature, skipUnlessDBFeature @@ -887,6 +896,39 @@ class SchemaTests(TransactionTestCase): editor.create_model(GeneratedFieldOutputFieldModel) @isolate_apps("schema") + @skipUnlessDBFeature("supports_stored_generated_columns") + def test_add_generated_field_contains(self): + class GeneratedFieldContainsModel(Model): + text = TextField(default="foo") + generated = GeneratedField( + expression=Concat("text", Value("%")), + db_persist=True, + output_field=TextField(), + ) + + class Meta: + app_label = "schema" + + with connection.schema_editor() as editor: + editor.create_model(GeneratedFieldContainsModel) + + field = GeneratedField( + expression=Q(text__icontains="FOO"), + db_persist=True, + output_field=BooleanField(), + ) + field.contribute_to_class(GeneratedFieldContainsModel, "contains_foo") + + with connection.schema_editor() as editor: + editor.add_field(GeneratedFieldContainsModel, field) + + obj = GeneratedFieldContainsModel.objects.create() + obj.refresh_from_db() + self.assertEqual(obj.text, "foo") + self.assertEqual(obj.generated, "foo%") + self.assertIs(obj.contains_foo, True) + + @isolate_apps("schema") def test_add_auto_field(self): class AddAutoFieldModel(Model): name = CharField(max_length=255, primary_key=True) |
