issue #627: add test and tweak Reaper behaviour.
parent
4bd0a234ce
commit
b21be478e4
@ -0,0 +1,54 @@
|
|||||||
|
|
||||||
|
import signal
|
||||||
|
import unittest2
|
||||||
|
import testlib
|
||||||
|
import mock
|
||||||
|
|
||||||
|
import mitogen.parent
|
||||||
|
|
||||||
|
|
||||||
|
class ReaperTest(testlib.TestCase):
|
||||||
|
@mock.patch('os.kill')
|
||||||
|
def test_calc_delay(self, kill):
|
||||||
|
broker = mock.Mock()
|
||||||
|
proc = mock.Mock()
|
||||||
|
proc.poll.return_value = None
|
||||||
|
reaper = mitogen.parent.Reaper(broker, proc, True, True)
|
||||||
|
self.assertEquals(50, int(1000 * reaper._calc_delay(0)))
|
||||||
|
self.assertEquals(86, int(1000 * reaper._calc_delay(1)))
|
||||||
|
self.assertEquals(147, int(1000 * reaper._calc_delay(2)))
|
||||||
|
self.assertEquals(254, int(1000 * reaper._calc_delay(3)))
|
||||||
|
self.assertEquals(437, int(1000 * reaper._calc_delay(4)))
|
||||||
|
self.assertEquals(752, int(1000 * reaper._calc_delay(5)))
|
||||||
|
self.assertEquals(1294, int(1000 * reaper._calc_delay(6)))
|
||||||
|
|
||||||
|
@mock.patch('os.kill')
|
||||||
|
def test_reap_calls(self, kill):
|
||||||
|
broker = mock.Mock()
|
||||||
|
proc = mock.Mock()
|
||||||
|
proc.poll.return_value = None
|
||||||
|
|
||||||
|
reaper = mitogen.parent.Reaper(broker, proc, True, True)
|
||||||
|
|
||||||
|
reaper.reap()
|
||||||
|
self.assertEquals(0, kill.call_count)
|
||||||
|
|
||||||
|
reaper.reap()
|
||||||
|
self.assertEquals(1, kill.call_count)
|
||||||
|
|
||||||
|
reaper.reap()
|
||||||
|
reaper.reap()
|
||||||
|
reaper.reap()
|
||||||
|
self.assertEquals(1, kill.call_count)
|
||||||
|
|
||||||
|
reaper.reap()
|
||||||
|
self.assertEquals(2, kill.call_count)
|
||||||
|
|
||||||
|
self.assertEquals(kill.mock_calls, [
|
||||||
|
mock.call(proc.pid, signal.SIGTERM),
|
||||||
|
mock.call(proc.pid, signal.SIGKILL),
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest2.main()
|
Loading…
Reference in New Issue