1
0
mirror of https://github.com/django/django.git synced 2025-10-24 22:26:08 +00:00

Refs #34986 -- Fixed backends.postgresql.test_server_side_cursors.ServerSideCursorsPostgres tests for PyPy.

This commit is contained in:
Nick Pope
2023-12-04 15:54:08 +00:00
committed by Mariusz Felisiak
parent 958a590e53
commit af6e7e3de8

View File

@@ -5,6 +5,8 @@ from contextlib import contextmanager
from django.db import connection, models from django.db import connection, models
from django.test import TestCase from django.test import TestCase
from django.test.utils import garbage_collect
from django.utils.version import PYPY
from ..models import Person from ..models import Person
@@ -88,14 +90,21 @@ class ServerSideCursorsPostgres(TestCase):
persons = Person.objects.iterator() persons = Person.objects.iterator()
next(persons) # Open a server-side cursor next(persons) # Open a server-side cursor
del persons del persons
garbage_collect()
cursors = self.inspect_cursors() cursors = self.inspect_cursors()
self.assertEqual(len(cursors), 0) self.assertEqual(len(cursors), 0)
@unittest.skipIf(
PYPY,
reason="Cursor not closed properly due to differences in garbage collection.",
)
def test_server_side_cursors_setting(self): def test_server_side_cursors_setting(self):
with self.override_db_setting(DISABLE_SERVER_SIDE_CURSORS=False): with self.override_db_setting(DISABLE_SERVER_SIDE_CURSORS=False):
persons = Person.objects.iterator() persons = Person.objects.iterator()
self.assertUsesCursor(persons) self.assertUsesCursor(persons)
del persons # Close server-side cursor del persons # Close server-side cursor
# On PyPy, the cursor is left open here and attempting to force garbage
# collection breaks the transaction wrapping the test.
with self.override_db_setting(DISABLE_SERVER_SIDE_CURSORS=True): with self.override_db_setting(DISABLE_SERVER_SIDE_CURSORS=True):
self.assertNotUsesCursor(Person.objects.iterator()) self.assertNotUsesCursor(Person.objects.iterator())