summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/asyncio/runners.py8
-rw-r--r--Lib/test/test_asyncio/test_runners.py19
2 files changed, 26 insertions, 1 deletions
diff --git a/Lib/asyncio/runners.py b/Lib/asyncio/runners.py
index 2bb9ca3..d274576 100644
--- a/Lib/asyncio/runners.py
+++ b/Lib/asyncio/runners.py
@@ -100,7 +100,13 @@ class Runner:
and signal.getsignal(signal.SIGINT) is signal.default_int_handler
):
sigint_handler = functools.partial(self._on_sigint, main_task=task)
- signal.signal(signal.SIGINT, sigint_handler)
+ try:
+ signal.signal(signal.SIGINT, sigint_handler)
+ except ValueError:
+ # `signal.signal` may throw if `threading.main_thread` does
+ # not support signals (e.g. embedded interpreter with signals
+ # not registered - see gh-91880)
+ signal_handler = None
else:
sigint_handler = None
diff --git a/Lib/test/test_asyncio/test_runners.py b/Lib/test/test_asyncio/test_runners.py
index 42aa07a..0c20921 100644
--- a/Lib/test/test_asyncio/test_runners.py
+++ b/Lib/test/test_asyncio/test_runners.py
@@ -3,10 +3,12 @@ import asyncio
import contextvars
import gc
import re
+import signal
import threading
import unittest
from unittest import mock
+from unittest.mock import patch
from test.test_asyncio import utils as test_utils
@@ -374,6 +376,23 @@ class RunnerTests(BaseTest):
with asyncio.Runner() as runner:
with self.assertRaises(asyncio.CancelledError):
runner.run(coro())
+
+ def test_signal_install_not_supported_ok(self):
+ # signal.signal() can throw if the "main thread" doensn't have signals enabled
+ assert threading.current_thread() is threading.main_thread()
+
+ async def coro():
+ pass
+
+ with asyncio.Runner() as runner:
+ with patch.object(
+ signal,
+ "signal",
+ side_effect=ValueError(
+ "signal only works in main thread of the main interpreter"
+ )
+ ):
+ runner.run(coro())
if __name__ == '__main__':