summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorMariusz Felisiak <felisiak.mariusz@gmail.com>2025-12-13 16:38:04 +0100
committerGitHub <noreply@github.com>2025-12-13 16:38:04 +0100
commit0174a85770356fd12e4c8daa42a4f1c752ae00e6 (patch)
tree716dee5c8e9e604b5f3889080ab66e860efde23c /tests
parente95468ed97b1c250939da316218c39dad577ba32 (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.py19
-rw-r--r--tests/model_fields/models.py6
-rw-r--r--tests/model_fields/test_generatedfield.py2
-rw-r--r--tests/schema/tests.py4
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(),