changeset: 90164:a6b764848b20 branch: 3.4 user: Victor Stinner date: Mon Apr 07 11:18:54 2014 +0200 files: Lib/asyncio/unix_events.py Lib/test/test_asyncio/test_events.py Misc/NEWS description: Issue #21155: asyncio.EventLoop.create_unix_server() now raises a ValueError if path and sock are specified at the same time. diff -r 027568b52a06 -r a6b764848b20 Lib/asyncio/unix_events.py --- a/Lib/asyncio/unix_events.py Mon Apr 07 11:18:06 2014 +0200 +++ b/Lib/asyncio/unix_events.py Mon Apr 07 11:18:54 2014 +0200 @@ -206,6 +206,10 @@ raise TypeError('ssl argument must be an SSLContext or None') if path is not None: + if sock is not None: + raise ValueError( + 'path and sock can not be specified at the same time') + sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM) try: diff -r 027568b52a06 -r a6b764848b20 Lib/test/test_asyncio/test_events.py --- a/Lib/test/test_asyncio/test_events.py Mon Apr 07 11:18:06 2014 +0200 +++ b/Lib/test/test_asyncio/test_events.py Mon Apr 07 11:18:54 2014 +0200 @@ -703,6 +703,17 @@ # close server server.close() + @unittest.skipUnless(hasattr(socket, 'AF_UNIX'), 'No UNIX Sockets') + def test_create_unix_server_path_socket_error(self): + proto = MyProto(loop=self.loop) + sock = socket.socket() + with sock: + f = self.loop.create_unix_server(lambda: proto, '/test', sock=sock) + with self.assertRaisesRegex(ValueError, + 'path and sock can not be specified ' + 'at the same time'): + server = self.loop.run_until_complete(f) + def _create_ssl_context(self, certfile, keyfile=None): sslcontext = ssl.SSLContext(ssl.PROTOCOL_SSLv23) sslcontext.options |= ssl.OP_NO_SSLv2 diff -r 027568b52a06 -r a6b764848b20 Misc/NEWS --- a/Misc/NEWS Mon Apr 07 11:18:06 2014 +0200 +++ b/Misc/NEWS Mon Apr 07 11:18:54 2014 +0200 @@ -27,6 +27,9 @@ Library ------- +- Issue #21155: asyncio.EventLoop.create_unix_server() now raises a ValueError + if path and sock are specified at the same time. + - Issue #21149: Improved thread-safety in logging cleanup during interpreter shutdown. Thanks to Devin Jeanpierre for the patch.