]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Merged revisions 84086 via svnmerge from
authorAntoine Pitrou <solipsis@pitrou.net>
Mon, 16 Aug 2010 00:32:47 +0000 (00:32 +0000)
committerAntoine Pitrou <solipsis@pitrou.net>
Mon, 16 Aug 2010 00:32:47 +0000 (00:32 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r84086 | antoine.pitrou | 2010-08-16 02:28:05 +0200 (lun., 16 août 2010) | 3 lines

  Save and restore the global asyncore.socket_map, and warn if a test modified it
........

Lib/test/regrtest.py

index 8a89a674be0ce8f9869d0e7b0340aa03fe74745e..fae5fe550705bc0ef7efe2149614ed3fa162e3e5 100755 (executable)
@@ -761,7 +761,7 @@ class saved_test_environment:
     # the corresponding method names.
 
     resources = ('sys.argv', 'cwd', 'sys.stdin', 'sys.stdout', 'sys.stderr',
-                 'os.environ', 'sys.path')
+                 'os.environ', 'sys.path', 'asyncore.socket_map')
 
     def get_sys_argv(self):
         return id(sys.argv), sys.argv, sys.argv[:]
@@ -802,6 +802,15 @@ class saved_test_environment:
         sys.path = saved_path[1]
         sys.path[:] = saved_path[2]
 
+    def get_asyncore_socket_map(self):
+        asyncore = sys.modules.get('asyncore')
+        return asyncore and asyncore.socket_map or {}
+    def restore_asyncore_socket_map(self, saved_map):
+        asyncore = sys.modules.get('asyncore')
+        if asyncore is not None:
+            asyncore.socket_map.clear()
+            asyncore.socket_map.update(saved_map)
+
     def resource_info(self):
         for name in self.resources:
             method_suffix = name.replace('.', '_')