From f0350f950643f398d3e448e99e9390ca7818ec83 2013-01-17 04:55:57 From: Brian E. Granger Date: 2013-01-17 04:55:57 Subject: [PATCH] Fixing bug in kernelmanager tests that was causing tests to hang. When calling restart and the interrupt quickly, the test suite was hanging. A simple time.sleep(1) fixes the problem. --- diff --git a/IPython/frontend/html/notebook/tests/test_kernelmanager.py b/IPython/frontend/html/notebook/tests/test_kernelmanager.py index f3ac9a5..870f1a9 100644 --- a/IPython/frontend/html/notebook/tests/test_kernelmanager.py +++ b/IPython/frontend/html/notebook/tests/test_kernelmanager.py @@ -1,5 +1,6 @@ """Tests for the notebook kernel and session manager.""" +import time from unittest import TestCase from IPython.config.loader import Config @@ -25,6 +26,13 @@ class TestKernelManager(TestCase): self.assertEqual(len(km),1) km.restart_kernel(kid) self.assertTrue(kid in km.list_kernel_ids()) + # We need a delay here to give the restarting kernel a chance to + # restart. Otherwise, the interrupt will kill it, causing the test + # suite to hang. The reason it *hangs* is that the shutdown + # message for the restart sometimes hasn't been sent to the kernel. + # Because linger is oo on the shell channel, the context can't + # close until the message is sent to the kernel, which is not dead. + time.sleep(1.0) km.interrupt_kernel(kid) k = km.get_kernel(kid) self.assertTrue(isinstance(k, KernelManager)) @@ -43,7 +51,7 @@ class TestKernelManager(TestCase): self.assertTrue('hb_port' in cinfo) km.shutdown_kernel(kid) - def test_km_tcp(self): + def test_tcp_lifecycle(self): km = self._get_tcp_km() self._run_lifecycle(km) @@ -51,10 +59,11 @@ class TestKernelManager(TestCase): km = self._get_tcp_km() self._run_cinfo(km, 'tcp', '127.0.0.1') - def test_km_ipc(self): + def test_ipc_lifecycle(self): km = self._get_ipc_km() self._run_lifecycle(km) def test_ipc_cinfo(self): km = self._get_ipc_km() self._run_cinfo(km, 'ipc', 'test') + diff --git a/IPython/zmq/kernelmanager.py b/IPython/zmq/kernelmanager.py index aa69112..3165902 100644 --- a/IPython/zmq/kernelmanager.py +++ b/IPython/zmq/kernelmanager.py @@ -201,7 +201,6 @@ class ShellChannel(ZMQSocketChannel): """The thread's main activity. Call start() instead.""" self.socket = self.context.socket(zmq.DEALER) self.socket.setsockopt(zmq.IDENTITY, self.session.bsession) - self.socket.linger = 0 self.socket.connect(self.address) self.stream = zmqstream.ZMQStream(self.socket, self.ioloop) self.stream.on_recv(self._handle_recv) diff --git a/IPython/zmq/tests/test_kernelmanager.py b/IPython/zmq/tests/test_kernelmanager.py index 271a74f..05313a6 100644 --- a/IPython/zmq/tests/test_kernelmanager.py +++ b/IPython/zmq/tests/test_kernelmanager.py @@ -1,5 +1,6 @@ """Tests for the notebook kernel and session manager.""" +import time from unittest import TestCase from IPython.config.loader import Config @@ -20,17 +21,24 @@ class TestKernelManager(TestCase): def _run_lifecycle(self, km): km.start_kernel() km.start_channels(shell=True, iopub=False, stdin=False, hb=False) - # km.shell_channel.start() km.restart_kernel() + # We need a delay here to give the restarting kernel a chance to + # restart. Otherwise, the interrupt will kill it, causing the test + # suite to hang. The reason it *hangs* is that the shutdown + # message for the restart sometimes hasn't been sent to the kernel. + # Because linger is oo on the shell channel, the context can't + # close until the message is sent to the kernel, which is not dead. + time.sleep() km.interrupt_kernel() self.assertTrue(isinstance(km, KernelManager)) km.shutdown_kernel() km.shell_channel.stop() - def test_km_tcp(self): + def test_tcp_lifecycle(self): km = self._get_tcp_km() self._run_lifecycle(km) - def test_km_ipc(self): + def testipc_lifecycle(self): km = self._get_ipc_km() self._run_lifecycle(km) +