mirror of
https://github.com/jupyter/notebook.git
synced 2025-01-24 12:05:22 +08:00
Popen.wait(timeout) is new in Python 3.3
This commit is contained in:
parent
b3c46ab2b4
commit
af2d60a393
@ -27,6 +27,23 @@ from IPython.utils.py3compat import bytes_to_str
|
|||||||
from IPython.utils.sysinfo import get_sys_info
|
from IPython.utils.sysinfo import get_sys_info
|
||||||
from IPython.utils.tempdir import TemporaryDirectory
|
from IPython.utils.tempdir import TemporaryDirectory
|
||||||
|
|
||||||
|
try:
|
||||||
|
# Python >= 3.3
|
||||||
|
from subprocess import TimeoutExpired
|
||||||
|
def popen_wait(p, timeout):
|
||||||
|
return p.wait(timeout)
|
||||||
|
except ImportError:
|
||||||
|
class TimeoutExpired(Exception):
|
||||||
|
pass
|
||||||
|
def popen_wait(p, timeout):
|
||||||
|
"""backport of Popen.wait from Python 3"""
|
||||||
|
for i in range(int(10 * timeout)):
|
||||||
|
if p.poll() is not None:
|
||||||
|
return
|
||||||
|
time.sleep(0.1)
|
||||||
|
if p.poll() is None:
|
||||||
|
raise TimeoutExpired
|
||||||
|
|
||||||
NOTEBOOK_SHUTDOWN_TIMEOUT = 10
|
NOTEBOOK_SHUTDOWN_TIMEOUT = 10
|
||||||
|
|
||||||
class TestController(object):
|
class TestController(object):
|
||||||
@ -283,8 +300,8 @@ class JSController(TestController):
|
|||||||
pass
|
pass
|
||||||
# wait 10s for the server to shutdown
|
# wait 10s for the server to shutdown
|
||||||
try:
|
try:
|
||||||
self.server.wait(NOTEBOOK_SHUTDOWN_TIMEOUT)
|
popen_wait(self.server, NOTEBOOK_SHUTDOWN_TIMEOUT)
|
||||||
except subprocess.TimeoutExpired:
|
except TimeoutExpired:
|
||||||
# server didn't terminate, kill it
|
# server didn't terminate, kill it
|
||||||
try:
|
try:
|
||||||
print("Failed to terminate notebook server, killing it.",
|
print("Failed to terminate notebook server, killing it.",
|
||||||
@ -296,8 +313,8 @@ class JSController(TestController):
|
|||||||
pass
|
pass
|
||||||
# wait another 10s
|
# wait another 10s
|
||||||
try:
|
try:
|
||||||
self.server.wait(NOTEBOOK_SHUTDOWN_TIMEOUT)
|
popen_wait(self.server, NOTEBOOK_SHUTDOWN_TIMEOUT)
|
||||||
except subprocess.TimeoutExpired:
|
except TimeoutExpired:
|
||||||
print("Notebook server still running (%s)" % self.server_info_file,
|
print("Notebook server still running (%s)" % self.server_info_file,
|
||||||
file=sys.stderr
|
file=sys.stderr
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user