Merged revisions 84086 via svnmerge from

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
........
This commit is contained in:
Antoine Pitrou 2010-08-16 00:32:47 +00:00
parent c7ff21687f
commit 1e8a75414f
1 changed files with 10 additions and 1 deletions

View File

@ -761,7 +761,7 @@ class saved_test_environment:
# the corresponding method names. # the corresponding method names.
resources = ('sys.argv', 'cwd', 'sys.stdin', 'sys.stdout', 'sys.stderr', 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): def get_sys_argv(self):
return id(sys.argv), sys.argv, sys.argv[:] 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[1]
sys.path[:] = saved_path[2] 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): def resource_info(self):
for name in self.resources: for name in self.resources:
method_suffix = name.replace('.', '_') method_suffix = name.replace('.', '_')