]> granicus.if.org Git - python/commitdiff
Issue #28704: Fix create_unix_server to support Path-like objects
authorYury Selivanov <yury@magic.io>
Tue, 15 Nov 2016 20:26:34 +0000 (15:26 -0500)
committerYury Selivanov <yury@magic.io>
Tue, 15 Nov 2016 20:26:34 +0000 (15:26 -0500)
Lib/asyncio/unix_events.py
Lib/test/test_asyncio/test_unix_events.py

index 788a5a09abf52ec8da74b6873b7456c2edeaef80..77905344fb7129931851e33ebca3d42bb63e9add 100644 (file)
@@ -39,6 +39,13 @@ def _sighandler_noop(signum, frame):
     pass
 
 
+try:
+    _fspath = os.fspath
+except AttributeError:
+    # Python 3.5 or earlier
+    _fspath = lambda path: path
+
+
 class _UnixSelectorEventLoop(selector_events.BaseSelectorEventLoop):
     """Unix event loop.
 
@@ -256,6 +263,7 @@ class _UnixSelectorEventLoop(selector_events.BaseSelectorEventLoop):
                 raise ValueError(
                     'path and sock can not be specified at the same time')
 
+            path = _fspath(path)
             sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
 
             # Check for abstract socket. `str` and `bytes` paths are supported.
index 89c6eed602bcc58fcb5f7837aec3d090702c91c6..5a499841352bf92f96a38a9afee19283a7502443 100644 (file)
@@ -4,6 +4,7 @@ import collections
 import errno
 import io
 import os
+import pathlib
 import signal
 import socket
 import stat
@@ -251,6 +252,15 @@ class SelectorEventLoopUnixSocketTests(test_utils.TestCase):
             srv.close()
             self.loop.run_until_complete(srv.wait_closed())
 
+    @unittest.skipUnless(hasattr(os, 'fspath'), 'no os.fspath')
+    def test_create_unix_server_pathlib(self):
+        with test_utils.unix_socket_path() as path:
+            path = pathlib.Path(path)
+            srv_coro = self.loop.create_unix_server(lambda: None, path)
+            srv = self.loop.run_until_complete(srv_coro)
+            srv.close()
+            self.loop.run_until_complete(srv.wait_closed())
+
     def test_create_unix_server_existing_path_nonsock(self):
         with tempfile.NamedTemporaryFile() as file:
             coro = self.loop.create_unix_server(lambda: None, file.name)