tests: merge tty_create_child() test into parent_test and fix hang
parent
6670cba41c
commit
bde1778373
@ -1,33 +0,0 @@
|
|||||||
|
|
||||||
import os
|
|
||||||
import tempfile
|
|
||||||
import time
|
|
||||||
import unittest2
|
|
||||||
|
|
||||||
import testlib
|
|
||||||
import mitogen.parent
|
|
||||||
|
|
||||||
|
|
||||||
class TtyCreateChildTest(unittest2.TestCase):
|
|
||||||
func = staticmethod(mitogen.parent.tty_create_child)
|
|
||||||
|
|
||||||
def test_dev_tty_open_succeeds(self):
|
|
||||||
tf = tempfile.NamedTemporaryFile()
|
|
||||||
try:
|
|
||||||
pid, fd = self.func(
|
|
||||||
'bash', '-c', 'exec 2>%s; echo hi > /dev/tty' % (tf.name,)
|
|
||||||
)
|
|
||||||
# TODO: this waitpid hangs on OS X. Installing a SIGCHLD handler
|
|
||||||
# reveals the parent /is/ notified of the child's death, but
|
|
||||||
# calling waitpid() from within SIGCHLD yields "No such processes".
|
|
||||||
# Meanwhile, even inserting a sleep, the following call will hang.
|
|
||||||
waited_pid, status = os.waitpid(pid, 0)
|
|
||||||
self.assertEquals(pid, waited_pid)
|
|
||||||
self.assertEquals(0, status)
|
|
||||||
self.assertEquals('', tf.read())
|
|
||||||
finally:
|
|
||||||
tf.close()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
unittest2.main()
|
|
Loading…
Reference in New Issue