Commit bd9c6d09 authored by Georg Brandl's avatar Georg Brandl

Merged revisions 83201 via svnmerge from

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

........
  r83201 | georg.brandl | 2010-07-28 10:19:35 +0200 (Mi, 28 Jul 2010) | 1 line

  #9354: Provide getsockopt() in asyncore file_wrapper().  Patch by Lukas Langa.
........
parent 77925b06
......@@ -598,6 +598,14 @@ if os.name == 'posix':
def send(self, *args):
return os.write(self.fd, *args)
def getsockopt(self, level, optname, buflen=None):
if (level == socket.SOL_SOCKET and
optname == socket.SO_ERROR and
not buflen):
return 0
raise NotImplementedError("Only asyncore specific behaviour "
"implemented.")
read = recv
write = send
......
......@@ -413,6 +413,19 @@ if hasattr(asyncore, 'file_wrapper'):
w.close()
self.assertEqual(open(TESTFN, 'rb').read(), self.d + d1 + d2)
@unittest.skipUnless(hasattr(asyncore, 'file_dispatcher'),
' asyncore.file_dispatcher required')
def test_dispatcher(self):
fd = os.open(TESTFN, os.O_RDONLY)
data = []
class FileDispatcher(asyncore.file_dispatcher):
def handle_read(self):
data.append(self.recv(29))
s = FileDispatcher(fd)
os.close(fd)
asyncore.loop(timeout=0.01, use_poll=True, count=2)
self.assertEqual(b"".join(data), self.d)
def test_main():
tests = [HelperFunctionTests, DispatcherTests, DispatcherWithSendTests,
......
......@@ -426,6 +426,7 @@ Hannu Krosing
Andrew Kuchling
Vladimir Kushnir
Cameron Laird
Łukasz Langa
Tino Lange
Andrew Langmead
Detlef Lannert
......
......@@ -127,6 +127,8 @@ Library
- Issue #1690103: Fix initial namespace for code run with trace.main().
- Issue #9354: Provide getsockopt() in asyncore's file_wrapper.
- Issue #9448: Fix a leak of OS resources (mutexes or semaphores) when
re-initializing a buffered IO object by calling its ``__init__`` method.
......
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