summaryrefslogtreecommitdiff
path: root/tests/backends/postgresql/test_compilation.py
diff options
context:
space:
mode:
authorSimon Charette <charette.s@gmail.com>2025-07-10 12:33:00 -0400
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2025-07-10 18:36:01 +0200
commit3df1ad57bfcabaf75e4617064d79610f185f3f9f (patch)
tree0e792629761bce12f1347eb2dfc3bb01b56ad8c9 /tests/backends/postgresql/test_compilation.py
parentabc10ab7f9ddc01807dd4afc33be21d3c302435d (diff)
[5.2.x] Fixed #36502 -- Restored UNNEST strategy for foreign key bulk inserts on PostgreSQL.
Regression in 764af7a3d6c0b543dcf659a2c327f214da768fe4. Backport of 0fe218842e0e396e3ab3982bd21227968a9e7fd8 from main.
Diffstat (limited to 'tests/backends/postgresql/test_compilation.py')
-rw-r--r--tests/backends/postgresql/test_compilation.py17
1 files changed, 16 insertions, 1 deletions
diff --git a/tests/backends/postgresql/test_compilation.py b/tests/backends/postgresql/test_compilation.py
index 67fe893e35..11c4015e01 100644
--- a/tests/backends/postgresql/test_compilation.py
+++ b/tests/backends/postgresql/test_compilation.py
@@ -1,10 +1,11 @@
import unittest
+from datetime import date
from django.db import connection
from django.db.models.expressions import RawSQL
from django.test import TestCase
-from ..models import Square
+from ..models import Article, Reporter, Square
@unittest.skipUnless(connection.vendor == "postgresql", "PostgreSQL tests")
@@ -27,3 +28,17 @@ class BulkCreateUnnestTests(TestCase):
[Square(root=2, square=4), Square(root=3, square=9)]
)
self.assertIn("UNNEST", ctx[0]["sql"])
+
+ def test_unnest_eligible_foreign_keys(self):
+ reporter = Reporter.objects.create()
+ with self.assertNumQueries(1) as ctx:
+ articles = Article.objects.bulk_create(
+ [
+ Article(pub_date=date.today(), reporter=reporter),
+ Article(pub_date=date.today(), reporter=reporter),
+ ]
+ )
+ self.assertIn("UNNEST", ctx[0]["sql"])
+ self.assertEqual(
+ [article.reporter for article in articles], [reporter, reporter]
+ )