Message 305118 - Python tracker

Message305118

Author erik.bray
Recipients erik.bray
Date 2017-10-27.13:08:09
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1509109689.46.0.213398074469.issue31882@psf.upfronthosting.co.za>
In-reply-to
Content
Some of the tests for asyncio and asyncore block forever on Cygwin, due to a known (and seemingly difficult to fix) bug [1] in Cygwin involving SO_PEERCRED on UNIX sockets.

SO_PEERCRED is a socket option that can be used to exchange file ownership info of the socket at the time the connection was established (specifically on UNIX sockets).  This feature is technically supported on Cygwin, but the effect of the bug is that if two sockets are opened on the same process (even without using socketpair()), the credential exchange protocol can cause connect() on the "client" socket to block unless the "server" socket is already listen()-ing.

This situation is not all that common in practice (it is not a problem if the "client" and "server" are separate processes).  But it does show up in the test suite in a number of places, since both sockets belong to the same process.

I have a patch to work around this and will post a PR shortly.

[1] https://cygwin.com/ml/cygwin/2017-01/msg00054.html
History
Date User Action Args
2017-10-27 13:08:09erik.braysetrecipients: + erik.bray
2017-10-27 13:08:09erik.braysetmessageid: <1509109689.46.0.213398074469.issue31882@psf.upfronthosting.co.za>
2017-10-27 13:08:09erik.braylinkissue31882 messages
2017-10-27 13:08:09erik.braycreate