Improved ExplainTests.test_basic().

QuerySet.select_for_update() is not supported by all databases.
Moreover it cannot be used outside of a transaction.
This commit is contained in:
Mariusz Felisiak 2022-04-13 10:17:14 +02:00 committed by GitHub
parent 27d52158b2
commit 0b63124c84
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 14 additions and 7 deletions

View File

@ -20,8 +20,9 @@ class ExplainTests(TestCase):
Tag.objects.filter(name="test").annotate(Count("children")), Tag.objects.filter(name="test").annotate(Count("children")),
Tag.objects.filter(name="test").values_list("name"), Tag.objects.filter(name="test").values_list("name"),
Tag.objects.order_by().union(Tag.objects.order_by().filter(name="test")), Tag.objects.order_by().union(Tag.objects.order_by().filter(name="test")),
Tag.objects.select_for_update().filter(name="test"),
] ]
if connection.features.has_select_for_update:
querysets.append(Tag.objects.select_for_update().filter(name="test"))
supported_formats = connection.features.supported_explain_formats supported_formats = connection.features.supported_explain_formats
all_formats = ( all_formats = (
(None,) (None,)
@ -31,14 +32,20 @@ class ExplainTests(TestCase):
for idx, queryset in enumerate(querysets): for idx, queryset in enumerate(querysets):
for format in all_formats: for format in all_formats:
with self.subTest(format=format, queryset=idx): with self.subTest(format=format, queryset=idx):
with self.assertNumQueries(1), CaptureQueriesContext( with CaptureQueriesContext(connection) as captured_queries:
connection if queryset.query.select_for_update:
) as captured_queries: with transaction.atomic():
result = queryset.explain(format=format) result = queryset.explain(format=format)
else:
result = queryset.explain(format=format)
self.assertEqual(len(captured_queries), 1)
self.assertTrue( self.assertTrue(
captured_queries[0]["sql"].startswith( any(
captured_query["sql"].startswith(
connection.ops.explain_prefix connection.ops.explain_prefix
) )
for captured_query in captured_queries
)
) )
self.assertIsInstance(result, str) self.assertIsInstance(result, str)
self.assertTrue(result) self.assertTrue(result)