summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Heimes <christian@python.org>2022-06-06 10:08:07 (GMT)
committerGitHub <noreply@github.com>2022-06-06 10:08:07 (GMT)
commit4c71d22c4f9fdde6f2234e7dc6a862419cd6fd98 (patch)
tree87b2959866966a09f8a5540ce09bdce2b4ddc9d5
parent9081bbd036934ab435291db9d32d02fd42282951 (diff)
downloadcpython-4c71d22c4f9fdde6f2234e7dc6a862419cd6fd98.zip
cpython-4c71d22c4f9fdde6f2234e7dc6a862419cd6fd98.tar.gz
cpython-4c71d22c4f9fdde6f2234e7dc6a862419cd6fd98.tar.bz2
gh-90473: WASI requires proper open(2) flags (GH-93529)
-rw-r--r--Lib/test/support/os_helper.py5
-rw-r--r--Lib/test/test_os.py3
-rw-r--r--Tools/wasm/README.md3
3 files changed, 9 insertions, 2 deletions
diff --git a/Lib/test/support/os_helper.py b/Lib/test/support/os_helper.py
index 5d787f1..a6ec1cf 100644
--- a/Lib/test/support/os_helper.py
+++ b/Lib/test/support/os_helper.py
@@ -463,7 +463,10 @@ def create_empty_file(filename):
def open_dir_fd(path):
"""Open a file descriptor to a directory."""
assert os.path.isdir(path)
- dir_fd = os.open(path, os.O_RDONLY)
+ flags = os.O_RDONLY
+ if hasattr(os, "O_DIRECTORY"):
+ flags |= os.O_DIRECTORY
+ dir_fd = os.open(path, flags)
try:
yield dir_fd
finally:
diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py
index f304c5e..c0321dc 100644
--- a/Lib/test/test_os.py
+++ b/Lib/test/test_os.py
@@ -3993,7 +3993,7 @@ class PathTConverterTests(unittest.TestCase):
('access', False, (os.F_OK,), None),
('chflags', False, (0,), None),
('lchflags', False, (0,), None),
- ('open', False, (0,), getattr(os, 'close', None)),
+ ('open', False, (os.O_RDONLY,), getattr(os, 'close', None)),
]
def test_path_t_converter(self):
@@ -4365,6 +4365,7 @@ class TestScandir(unittest.TestCase):
st = os.stat(entry.name, dir_fd=fd, follow_symlinks=False)
self.assertEqual(entry.stat(follow_symlinks=False), st)
+ @unittest.skipIf(support.is_wasi, "WASI maps '' to cwd")
def test_empty_path(self):
self.assertRaises(FileNotFoundError, os.scandir, '')
diff --git a/Tools/wasm/README.md b/Tools/wasm/README.md
index 6bb9bd9..3b7a7ae 100644
--- a/Tools/wasm/README.md
+++ b/Tools/wasm/README.md
@@ -235,6 +235,9 @@ are:
call read/write/accept on a file descriptor that is passed into the process.
- ``socket.gethostname()`` and host name resolution APIs like
``socket.gethostbyname()`` are not implemented and always fail.
+- ``open(2)`` checks flags more strictly. Caller must pass either
+ ``O_RDONLY``, ``O_RDWR``, or ``O_WDONLY`` to ``os.open``. Directory file
+ descriptors must be created with flags ``O_RDONLY | O_DIRECTORY``.
- ``chmod(2)`` is not available. It's not possible to modify file permissions,
yet. A future version of WASI may provide a limited ``set_permissions`` API.
- User/group related features like ``os.chown()``, ``os.getuid``, etc. are