diff options
| author | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2025-12-13 16:38:04 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-12-13 16:38:04 +0100 |
| commit | 0174a85770356fd12e4c8daa42a4f1c752ae00e6 (patch) | |
| tree | 716dee5c8e9e604b5f3889080ab66e860efde23c /tests | |
| parent | e95468ed97b1c250939da316218c39dad577ba32 (diff) | |
Fixed #36765 -- Added support for stored GeneratedFields on Oracle 23ai/26ai (23.7+).
Thanks Jacob Walls for the review.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/migrations/test_operations.py | 19 | ||||
| -rw-r--r-- | tests/model_fields/models.py | 6 | ||||
| -rw-r--r-- | tests/model_fields/test_generatedfield.py | 2 | ||||
| -rw-r--r-- | tests/schema/tests.py | 4 |
4 files changed, 21 insertions, 10 deletions
diff --git a/tests/migrations/test_operations.py b/tests/migrations/test_operations.py index ec4b772c13..00c76538e0 100644 --- a/tests/migrations/test_operations.py +++ b/tests/migrations/test_operations.py @@ -1491,7 +1491,7 @@ class OperationTests(OperationTestBase): "name_and_id", models.GeneratedField( expression=Concat(("name"), ("rider_id")), - output_field=models.TextField(), + output_field=models.CharField(max_length=60), db_persist=True, ), ), @@ -6363,6 +6363,15 @@ class OperationTests(OperationTestBase): ("test_igfc_2", generated_1, regular), ("test_igfc_3", generated_1, generated_2), ] + if not connection.features.supports_alter_generated_column_data_type: + generated_3 = models.GeneratedField( + expression=F("pink") + F("pink"), + output_field=models.DecimalField(decimal_places=2, max_digits=16), + db_persist=db_persist, + ) + tests.append( + ("test_igfc_4", generated_1, generated_3), + ) for app_label, add_field, alter_field in tests: project_state = self.set_up_test_model(app_label) operations = [ @@ -6441,7 +6450,7 @@ class OperationTests(OperationTestBase): "Pony", "modified_pink", models.GeneratedField( - expression=F("pink"), + expression=F("pink") + 2, output_field=models.IntegerField(), db_persist=True, ), @@ -6450,7 +6459,7 @@ class OperationTests(OperationTestBase): "Pony", "modified_pink", models.GeneratedField( - expression=F("pink"), + expression=F("pink") + 2, output_field=models.IntegerField(), db_persist=False, ), @@ -6489,7 +6498,9 @@ class OperationTests(OperationTestBase): operation.database_backwards(app_label, editor, new_state, project_state) self.assertColumnNotExists(f"{app_label}_pony", "modified_pink") - @skipUnlessDBFeature("supports_stored_generated_columns") + @skipUnlessDBFeature( + "supports_stored_generated_columns", "supports_alter_generated_column_data_type" + ) def test_generated_field_changes_output_field(self): app_label = "test_gfcof" operation = migrations.AddField( diff --git a/tests/model_fields/models.py b/tests/model_fields/models.py index 816e5a16ba..800a9ff5aa 100644 --- a/tests/model_fields/models.py +++ b/tests/model_fields/models.py @@ -9,7 +9,7 @@ from django.core.serializers.json import DjangoJSONEncoder from django.db import connection, models from django.db.models import F, Value from django.db.models.fields.files import ImageFieldFile -from django.db.models.functions import Lower +from django.db.models.functions import Cast, Lower from django.utils.functional import SimpleLazyObject from django.utils.translation import gettext_lazy as _ @@ -534,7 +534,7 @@ class UUIDGrandchild(UUIDChild): class GeneratedModelFieldWithConverters(models.Model): field = models.UUIDField() field_copy = models.GeneratedField( - expression=F("field"), + expression=Cast("field", models.UUIDField()), output_field=models.UUIDField(), db_persist=True, ) @@ -561,7 +561,7 @@ class GeneratedModelNonAutoPk(models.Model): id = models.IntegerField(primary_key=True) a = models.IntegerField() b = models.GeneratedField( - expression=F("a"), + expression=F("a") + 1, output_field=models.IntegerField(), db_persist=True, ) diff --git a/tests/model_fields/test_generatedfield.py b/tests/model_fields/test_generatedfield.py index f0ac6eecb5..161084ecef 100644 --- a/tests/model_fields/test_generatedfield.py +++ b/tests/model_fields/test_generatedfield.py @@ -413,7 +413,7 @@ class StoredGeneratedFieldTests(GeneratedFieldTestMixin, TestCase): obj = GeneratedModelNonAutoPk.objects.create(id=1, a=2) self.assertEqual(obj.id, 1) self.assertEqual(obj.a, 2) - self.assertEqual(obj.b, 2) + self.assertEqual(obj.b, 3) @skipUnlessDBFeature("supports_virtual_generated_columns") diff --git a/tests/schema/tests.py b/tests/schema/tests.py index ab8b07e9d3..12c14563e0 100644 --- a/tests/schema/tests.py +++ b/tests/schema/tests.py @@ -1029,7 +1029,7 @@ class SchemaTests(TransactionTestCase): class GeneratedFieldIndexedModel(Model): number = IntegerField(default=1) generated = GeneratedField( - expression=F("number"), + expression=F("number") + 1, db_persist=True, output_field=IntegerField(), ) @@ -1042,7 +1042,7 @@ class SchemaTests(TransactionTestCase): old_field = GeneratedFieldIndexedModel._meta.get_field("generated") new_field = GeneratedField( - expression=F("number"), + expression=F("number") + 1, db_persist=True, db_index=True, output_field=IntegerField(), |
