bpo-33792: Add selector and proactor windows policies (GH-7487)
(cherry picked from commit 8f4042964d5b0ddf5cdf87862db962ba64e3f64a)
Co-authored-by: Yury Selivanov <yury@magic.io>
diff --git a/Lib/asyncio/windows_events.py b/Lib/asyncio/windows_events.py
index d22edec..2ec5427 100644
--- a/Lib/asyncio/windows_events.py
+++ b/Lib/asyncio/windows_events.py
@@ -21,7 +21,8 @@
__all__ = (
'SelectorEventLoop', 'ProactorEventLoop', 'IocpProactor',
- 'DefaultEventLoopPolicy',
+ 'DefaultEventLoopPolicy', 'WindowsSelectorEventLoopPolicy',
+ 'WindowsProactorEventLoopPolicy',
)
@@ -801,8 +802,12 @@
SelectorEventLoop = _WindowsSelectorEventLoop
-class _WindowsDefaultEventLoopPolicy(events.BaseDefaultEventLoopPolicy):
+class WindowsSelectorEventLoopPolicy(events.BaseDefaultEventLoopPolicy):
_loop_factory = SelectorEventLoop
-DefaultEventLoopPolicy = _WindowsDefaultEventLoopPolicy
+class WindowsProactorEventLoopPolicy(events.BaseDefaultEventLoopPolicy):
+ _loop_factory = ProactorEventLoop
+
+
+DefaultEventLoopPolicy = WindowsSelectorEventLoopPolicy
diff --git a/Lib/test/test_asyncio/test_windows_events.py b/Lib/test/test_asyncio/test_windows_events.py
index e4ff7fc..15d933d 100644
--- a/Lib/test/test_asyncio/test_windows_events.py
+++ b/Lib/test/test_asyncio/test_windows_events.py
@@ -162,5 +162,36 @@
fut.cancel()
+class WinPolicyTests(test_utils.TestCase):
+
+ def test_selector_win_policy(self):
+ async def main():
+ self.assertIsInstance(
+ asyncio.get_running_loop(),
+ asyncio.SelectorEventLoop)
+
+ old_policy = asyncio.get_event_loop_policy()
+ try:
+ asyncio.set_event_loop_policy(
+ asyncio.WindowsSelectorEventLoopPolicy())
+ asyncio.run(main())
+ finally:
+ asyncio.set_event_loop_policy(old_policy)
+
+ def test_proactor_win_policy(self):
+ async def main():
+ self.assertIsInstance(
+ asyncio.get_running_loop(),
+ asyncio.ProactorEventLoop)
+
+ old_policy = asyncio.get_event_loop_policy()
+ try:
+ asyncio.set_event_loop_policy(
+ asyncio.WindowsProactorEventLoopPolicy())
+ asyncio.run(main())
+ finally:
+ asyncio.set_event_loop_policy(old_policy)
+
+
if __name__ == '__main__':
unittest.main()