mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
bpo-31922: Do not connect UDP sockets when broadcast is allowed (GH-423)
*Moved from python/asyncio#493.* This PR fixes issue python/asyncio#480, as explained in [this comment](https://github.com/python/asyncio/issues/480#issuecomment-278703828). The `_SelectorDatagramTransport.sendto` method has to be modified ~~so `_sock.sendto` is used in all cases (because it is tricky to reliably tell if the socket is connected or not). Could that be an issue for connected sockets?~~ *EDIT* ... so `_sock.send` is used only if `_sock` is connected. It also protects `socket.getsockname` against `OSError` in `_SelectorTransport`. This might happen on Windows if the socket is not connected (e.g. for UDP broadcasting). https://bugs.python.org/issue31922
This commit is contained in:
parent
91cc01f40e
commit
63deaa5b70
5 changed files with 34 additions and 7 deletions
|
@ -1586,6 +1586,23 @@ class BaseEventLoopWithSelectorTests(test_utils.TestCase):
|
|||
self.assertRaises(
|
||||
OSError, self.loop.run_until_complete, coro)
|
||||
|
||||
def test_create_datagram_endpoint_allow_broadcast(self):
|
||||
protocol = MyDatagramProto(create_future=True, loop=self.loop)
|
||||
self.loop.sock_connect = sock_connect = mock.Mock()
|
||||
sock_connect.return_value = []
|
||||
|
||||
coro = self.loop.create_datagram_endpoint(
|
||||
lambda: protocol,
|
||||
remote_addr=('127.0.0.1', 0),
|
||||
allow_broadcast=True)
|
||||
|
||||
transport, _ = self.loop.run_until_complete(coro)
|
||||
self.assertFalse(sock_connect.called)
|
||||
|
||||
transport.close()
|
||||
self.loop.run_until_complete(protocol.done)
|
||||
self.assertEqual('CLOSED', protocol.state)
|
||||
|
||||
@patch_socket
|
||||
def test_create_datagram_endpoint_socket_err(self, m_socket):
|
||||
m_socket.getaddrinfo = socket.getaddrinfo
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue