Fix for issue 14725 for 3.2 branch
authorRichard Oudkerk <shibturn@gmail.com>
Sat, 5 May 2012 19:41:23 +0000 (20:41 +0100)
committerRichard Oudkerk <shibturn@gmail.com>
Sat, 5 May 2012 19:41:23 +0000 (20:41 +0100)
Lib/multiprocessing/connection.py
Lib/test/test_multiprocessing.py
Modules/_multiprocessing/win32_functions.c

index 8bb0a3b0d83d9f1f3077ae7d6255de188005b8cb..f537a36ca43957d628b391e140608f3e448fa982 100644 (file)
@@ -360,7 +360,10 @@ if sys.platform == 'win32':
             try:
                 win32.ConnectNamedPipe(handle, win32.NULL)
             except WindowsError as e:
-                if e.args[0] != win32.ERROR_PIPE_CONNECTED:
+                # ERROR_NO_DATA can occur if a client has already connected,
+                # written data and then disconnected -- see Issue 14725.
+                if e.args[0] not in (win32.ERROR_PIPE_CONNECTED,
+                                     win32.ERROR_NO_DATA):
                     raise
             return _multiprocessing.PipeConnection(handle)
 
index 298faf73fd5d9cbda1bb23f3ce0d2448b6e225ce..5f1bba32a279ed16b5177d679a7acbff39bfaa0d 100644 (file)
@@ -1732,6 +1732,23 @@ class _TestListenerClient(BaseTestCase):
             self.assertEqual(conn.recv(), 'hello')
             p.join()
             l.close()
+
+    def test_issue14725(self):
+        l = self.connection.Listener()
+        p = self.Process(target=self._test, args=(l.address,))
+        p.daemon = True
+        p.start()
+        time.sleep(1)
+        # On Windows the client process should by now have connected,
+        # written data and closed the pipe handle by now.  This causes
+        # ConnectNamdedPipe() to fail with ERROR_NO_DATA.  See Issue
+        # 14725.
+        conn = l.accept()
+        self.assertEqual(conn.recv(), 'hello')
+        conn.close()
+        p.join()
+        l.close()
+
 #
 # Test of sending connection and socket objects between processes
 #
index 452d6086485a2e24ec447cb4e119a4cdd80cdda5..0e348c4134f276298368ff7b93ec0d5782c78e1f 100644 (file)
@@ -244,6 +244,7 @@ create_win32_namespace(void)
     Py_INCREF(&Win32Type);
 
     WIN32_CONSTANT(F_DWORD, ERROR_ALREADY_EXISTS);
+    WIN32_CONSTANT(F_DWORD, ERROR_NO_DATA);
     WIN32_CONSTANT(F_DWORD, ERROR_PIPE_BUSY);
     WIN32_CONSTANT(F_DWORD, ERROR_PIPE_CONNECTED);
     WIN32_CONSTANT(F_DWORD, ERROR_SEM_TIMEOUT);