pass
+# WASI does not have a temp directory and uses cwd instead. The cwd contains
+# non-ASCII chars, so _walk_dir() fails to encode self.directory.
+@unittest.skipIf(support.is_wasi, "tempdir is not encodable on WASI")
class EncodingTest(unittest.TestCase):
"""Issue 6716: compileall should escape source code when printing errors
to stdout."""
from test.support import os_helper
from test.support import (
- STDLIB_DIR, is_jython, swap_attr, swap_item, cpython_only, is_emscripten)
+ STDLIB_DIR, is_jython, swap_attr, swap_item, cpython_only, is_emscripten,
+ is_wasi)
from test.support.import_helper import (
forget, make_legacy_pyc, unlink, unload, DirsOnSysPath, CleanImport)
from test.support.os_helper import (
@unittest.skipUnless(os.name == 'posix',
"test meaningful only on posix systems")
- @unittest.skipIf(is_emscripten, "Emscripten's umask is a stub.")
+ @unittest.skipIf(
+ is_emscripten or is_wasi,
+ "Emscripten's/WASI's umask is a stub."
+ )
def test_creation_mode(self):
mask = 0o022
with temp_umask(mask), _ready_to_import() as (name, path):
@unittest.skipIf(
support.is_emscripten, "Test is unstable under Emscripten."
)
+ @unittest.skipIf(
+ support.is_wasi, "WASI does not support dup."
+ )
def test_closerange(self):
first = os.open(os_helper.TESTFN, os.O_CREAT|os.O_RDWR)
# We must allocate two consecutive file descriptors, otherwise
'dir5', 'dir6')
os.makedirs(path)
- @unittest.skipIf(support.is_emscripten, "Emscripten's umask is a stub.")
+ @unittest.skipIf(
+ support.is_emscripten or support.is_wasi,
+ "Emscripten's/WASI's umask is a stub."
+ )
def test_mode(self):
with os_helper.temp_umask(0o002):
base = os_helper.TESTFN
@unittest.skipIf(
is_emscripten, "Unix sockets are not implemented on Emscripten."
)
+ @unittest.skipIf(
+ is_wasi, "Cannot create socket on WASI."
+ )
def test_is_socket_true(self):
P = self.cls(BASE, 'mysock')
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
self.assertEqual(expected, actual)
+ @unittest.skipIf(support.is_wasi, "WASI has no /dev/null")
def test_fallback(self):
with os_helper.EnvironmentVarGuard() as env:
del env['LINES']
``socket.gethostbyname()`` are not implemented and always fail.
- ``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
+ stubs or fail with ``ENOTSUP``.
- File locking (``fcntl``) is not available.
- ``os.pipe()``, ``os.mkfifo()``, and ``os.mknod()`` are not supported.
- ``process_time`` does not work as expected because it's implemented using
wall clock.
-- ``os.umask`` is a stub.
+- ``os.umask()`` is a stub.
- ``sys.executable`` is empty.
- ``/dev/null`` / ``os.devnull`` may not be available.
+- ``os.utime*()`` is buggy in WASM SDK 15.0, see
+ [utimensat() with timespec=NULL sets wrong time](https://github.com/bytecodealliance/wasmtime/issues/4184)
+- ``os.symlink()`` fails with ``PermissionError`` when attempting to create a
+ symlink with an absolute path with wasmtime 0.36.0. The wasmtime runtime
+ uses ``openat2(2)`` syscall with flag ``RESOLVE_BENEATH`` to open files.
+ The flag causes the syscall to reject symlinks with absolute paths.
+- ``os.curdir`` (aka ``.``) seems to behave differently, which breaks some
+ ``importlib`` tests that add ``.`` to ``sys.path`` and indirectly
+ ``sys.path_importer_cache``.
+- WASI runtime environments may not provide a dedicated temp directory.
# Detect WebAssembly builds
ac_cv_func_mkfifoat=no
ac_cv_func_mknod=no
ac_cv_func_mknodat=no
+ac_cv_func_makedev=no
# fdopendir() fails on SDK 15.0,
# OSError: [Errno 28] Invalid argument: '.'
py_cv_module__ctypes_test=n/a
py_cv_module_fcntl=n/a
+ py_cv_module_mmap=n/a
+ py_cv_module_resource=n/a
+ py_cv_module_termios=n/a
py_cv_module_=n/a
],
[Emscripten/node*], [],
[WASI/*], [
- dnl WASI SDK 15.0 does not support file locking.
+ dnl WASI SDK 15.0 does not support file locking, mmap, and more.
PY_STDLIB_MOD_SET_NA(
[_ctypes_test],
- [fcntl],
+ [fcntl],
+ [mmap],
+ [resource],
+ [termios],
)
]
)