Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PYTHON-5167 Properly cleanup test SocketGetter tasks #2176

Merged

Conversation

ShaneHarvey
Copy link
Member

@ShaneHarvey ShaneHarvey commented Mar 3, 2025

PYTHON-5167 Properly cleanup test SocketGetter tasks

Should resolve one of the errors seen in SocketGetter.run_mongo_thread:

FAILED test/asynchronous/test_session.py::TestSession::test_end_sessions - pytest.PytestUnraisableExceptionWarning: Exception ignored in: <coroutine object SocketGetter.run_mongo_thread at 0x4dc35c00a00>

Traceback (most recent call last):
  File "/home/runner/work/mongo-python-driver/mongo-python-driver/pymongo/asynchronous/pool.py", line 1474, in _get_conn
    if not await _async_cond_wait(self.size_cond, timeout):
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
GeneratorExit

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/home/runner/work/mongo-python-driver/mongo-python-driver/test/asynchronous/test_pooling.py", line 120, in run_mongo_thread
    async with self.pool.checkout() as sock:
               ~~~~~~~~~~~~~~~~~~^^
  File "/home/runner/.local/share/uv/python/cpython-3.13.2+freethreaded-linux-x86_64-gnu/lib/python3.13t/contextlib.py", line 214, in __aenter__
    return await anext(self.gen)
           ^^^^^^^^^^^^^^^^^^^^^
  File "/home/runner/work/mongo-python-driver/mongo-python-driver/pymongo/asynchronous/pool.py", line 1355, in checkout
    conn = await self._get_conn(checkout_started_time, handler=handler)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/runner/work/mongo-python-driver/mongo-python-driver/pymongo/asynchronous/pool.py", line 1470, in _get_conn
    async with self.size_cond:
               ^^^^^^^^^^^^^^
  File "/home/runner/.local/share/uv/python/cpython-3.13.2+freethreaded-linux-x86_64-gnu/lib/python3.13t/asyncio/locks.py", line 20, in __aexit__
    self.release()
    ~~~~~~~~~~~~^^
  File "/home/runner/.local/share/uv/python/cpython-3.13.2+freethreaded-linux-x86_64-gnu/lib/python3.13t/asyncio/locks.py", line 142, in release
Error:     raise RuntimeError('Lock is not acquired.')
RuntimeError: Lock is not acquired.

@ShaneHarvey ShaneHarvey requested review from NoahStapp and sleepyStick and removed request for NoahStapp March 3, 2025 21:31
@ShaneHarvey ShaneHarvey merged commit 9edfc62 into mongodb:master Mar 4, 2025
46 of 51 checks passed
@ShaneHarvey ShaneHarvey deleted the PYTHON-5167-cleanup-SocketGetter branch March 4, 2025 23:22
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants