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

Manage asyncio loop creation manually #7591

Merged
merged 35 commits into from
Jan 7, 2025
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
e60c1fc
Manage asyncio loop creation manually
philippjfr Jan 6, 2025
95921e2
Handle async task scheduling manually
philippjfr Jan 6, 2025
40c8f72
Small fixes
philippjfr Jan 6, 2025
2bb86d9
Do not use async tests for threaded executions
philippjfr Jan 6, 2025
559f058
Do not set up global event loop
philippjfr Jan 6, 2025
de6bef1
Update async tests consistently
philippjfr Jan 6, 2025
4096d4a
Declare async tests
philippjfr Jan 6, 2025
a1c8af3
Ensure an event loop is set
philippjfr Jan 6, 2025
2682b26
More async tests
philippjfr Jan 6, 2025
44fee87
More changes
philippjfr Jan 6, 2025
821f9ef
Fix all async chat tests
philippjfr Jan 6, 2025
e23a297
Do not create Tornado IOLoop
philippjfr Jan 6, 2025
36977ce
Fix test
philippjfr Jan 6, 2025
76ed9d4
Small adjustments
philippjfr Jan 6, 2025
f620db9
Cleanup thread pool for ioloops
philippjfr Jan 6, 2025
3442e8d
Ensure streamz event loop gets shut down
philippjfr Jan 6, 2025
85d1ada
Revert changes to async_execute
philippjfr Jan 6, 2025
0e3c9a4
Make doc tests async
philippjfr Jan 6, 2025
6caabf9
Re-enable test
philippjfr Jan 6, 2025
bd21e64
fix types
philippjfr Jan 6, 2025
93ad2fc
Remove loop creation and cleanup
philippjfr Jan 7, 2025
933273c
Fixes
philippjfr Jan 7, 2025
9dabd29
Disable autouse on asyncio_loop
philippjfr Jan 7, 2025
78aaa36
Do not reuse ioloop
philippjfr Jan 7, 2025
bc4586a
Explicit asyncio loop for subprocess tests
philippjfr Jan 7, 2025
89fc247
Avoid creating Tornado IOLoop again
philippjfr Jan 7, 2025
50af057
Minor fixes
philippjfr Jan 7, 2025
e16a019
Updates to jupyterlite pins
philippjfr Jan 7, 2025
55c6a28
Bump lock version
philippjfr Jan 7, 2025
51a106d
Fix pins
philippjfr Jan 7, 2025
fda7cfd
Do not use custom bokeh wheel for now
philippjfr Jan 7, 2025
32ba68e
Do not piggyback on Tornado event loop for periodic callbacks
philippjfr Jan 7, 2025
ae6a11b
Make tests more robust
philippjfr Jan 7, 2025
62e3564
Use async test instead of explicit loop
philippjfr Jan 7, 2025
35ff450
Fix PeriodicCallback.stop()
philippjfr Jan 7, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Minor fixes
  • Loading branch information
philippjfr committed Jan 7, 2025
commit 50af0574635c2fc4563bfa0d292e8304e6ffd5f2
3 changes: 2 additions & 1 deletion panel/io/server.py
Original file line number Diff line number Diff line change
Expand Up @@ -125,8 +125,9 @@ def async_execute(func: Callable[..., None]) -> None:
except RuntimeError:
loop = asyncio.new_event_loop()
asyncio.set_event_loop(loop)
# Avoid creating IOLoop if one is not already associated
# with the asyncio loop or we're on a child thread
if hasattr(IOLoop, '_ioloop_for_asyncio') and loop in IOLoop._ioloop_for_asyncio:
# Avoid creating a Tornado IOLoop unless it already exists
ioloop = IOLoop._ioloop_for_asyncio[loop]
elif threading.current_thread() is not threading.main_thread():
ioloop = IOLoop.current()
Expand Down
2 changes: 1 addition & 1 deletion panel/tests/chat/test_feed.py
Original file line number Diff line number Diff line change
Expand Up @@ -900,7 +900,7 @@ def echo(contents, user, instance):
chat_feed.send("Message", respond=True)
await async_wait_until(lambda: len(chat_feed.objects) == 2)
await async_wait_until(lambda: chat_feed.objects[1].object == "Message")
assert not chat_feed.objects[-1].show_activity_dot
await async_wait_until(lambda: not chat_feed.objects[-1].show_activity_dot)

@pytest.mark.parametrize("key", ["value", "object"])
async def test_generator_dict(self, chat_feed, key):
Expand Down
Loading