Commit 927f4560 authored by Hirokazu Yamamoto's avatar Hirokazu Yamamoto

Merged revisions 85315 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r85315 | hirokazu.yamamoto | 2010-10-08 17:38:15 +0900 | 1 line

  Issue #9978: Wait until subprocess completes initialization. (Win32KillTests in test_os)
........
parent 543ee0f1
...@@ -11,6 +11,8 @@ import signal ...@@ -11,6 +11,8 @@ import signal
import subprocess import subprocess
import time import time
from test import test_support from test import test_support
import mmap
import uuid
warnings.filterwarnings("ignore", "tempnam", RuntimeWarning, __name__) warnings.filterwarnings("ignore", "tempnam", RuntimeWarning, __name__)
warnings.filterwarnings("ignore", "tmpnam", RuntimeWarning, __name__) warnings.filterwarnings("ignore", "tmpnam", RuntimeWarning, __name__)
...@@ -736,13 +738,23 @@ class Win32KillTests(unittest.TestCase): ...@@ -736,13 +738,23 @@ class Win32KillTests(unittest.TestCase):
self._kill(100) self._kill(100)
def _kill_with_event(self, event, name): def _kill_with_event(self, event, name):
tagname = "test_os_%s" % uuid.uuid1()
m = mmap.mmap(-1, 1, tagname)
m[0] = '0'
# Run a script which has console control handling enabled. # Run a script which has console control handling enabled.
proc = subprocess.Popen([sys.executable, proc = subprocess.Popen([sys.executable,
os.path.join(os.path.dirname(__file__), os.path.join(os.path.dirname(__file__),
"win_console_handler.py")], "win_console_handler.py"), tagname],
creationflags=subprocess.CREATE_NEW_PROCESS_GROUP) creationflags=subprocess.CREATE_NEW_PROCESS_GROUP)
# Let the interpreter startup before we send signals. See #3137. # Let the interpreter startup before we send signals. See #3137.
time.sleep(0.5) count, max = 0, 20
while count < max and proc.poll() is None:
if m[0] == '0':
break
time.sleep(0.5)
count += 1
else:
self.fail("Subprocess didn't finish initialization")
os.kill(proc.pid, event) os.kill(proc.pid, event)
# proc.send_signal(event) could also be done here. # proc.send_signal(event) could also be done here.
# Allow time for the signal to be passed and the process to exit. # Allow time for the signal to be passed and the process to exit.
......
...@@ -11,6 +11,8 @@ similar example in C. ...@@ -11,6 +11,8 @@ similar example in C.
from ctypes import wintypes, WINFUNCTYPE from ctypes import wintypes, WINFUNCTYPE
import signal import signal
import ctypes import ctypes
import mmap
import sys
# Function prototype for the handler function. Returns BOOL, takes a DWORD. # Function prototype for the handler function. Returns BOOL, takes a DWORD.
HandlerRoutine = WINFUNCTYPE(wintypes.BOOL, wintypes.DWORD) HandlerRoutine = WINFUNCTYPE(wintypes.BOOL, wintypes.DWORD)
...@@ -38,6 +40,10 @@ if __name__ == "__main__": ...@@ -38,6 +40,10 @@ if __name__ == "__main__":
print("Unable to add SetConsoleCtrlHandler") print("Unable to add SetConsoleCtrlHandler")
exit(-1) exit(-1)
# Awaken mail process
m = mmap.mmap(-1, 1, sys.argv[1])
m[0] = '1'
# Do nothing but wait for the signal # Do nothing but wait for the signal
while True: while True:
pass pass
...@@ -403,6 +403,9 @@ Build ...@@ -403,6 +403,9 @@ Build
Tests Tests
----- -----
- Issue #9978: Wait until subprocess completes initialization. (Win32KillTests
in test_os)
- Issue #9894: Do not hardcode ENOENT in test_subprocess. - Issue #9894: Do not hardcode ENOENT in test_subprocess.
- Issue #9323: Make test.regrtest.__file__ absolute, this was not always the - Issue #9323: Make test.regrtest.__file__ absolute, this was not always the
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment