summaryrefslogtreecommitdiff
path: root/cli/tests
diff options
context:
space:
mode:
authorAndreu Botella <abb@randomunok.com>2021-11-26 09:52:41 +0100
committerGitHub <noreply@github.com>2021-11-26 19:52:41 +1100
commitd763633781be484bb19b458208dd7c11efb83228 (patch)
treea165f0eefad95df88a0fa50e6bc2412044d7a2cc /cli/tests
parent6a780543a43d4d370c42b557955200c59bcb21e8 (diff)
feat(etc/fetch): Support `WebAssembly.instantiateStreaming` for file fetches (#12901)
Fetching of local files, added in #12545, returns a response with no headers, including the `Content-Type` header. This currently makes it not work with the WebAssembly streaming APIs, which require the response to have a content type of `application/wasm`. Since the only way to obtain a `Response` object with a non-empty `url` field is via `fetch()`, this change changes the content type requirement to only apply to responses whose url has the `file:` scheme.
Diffstat (limited to 'cli/tests')
-rw-r--r--cli/tests/unit/wasm_test.ts14
1 files changed, 14 insertions, 0 deletions
diff --git a/cli/tests/unit/wasm_test.ts b/cli/tests/unit/wasm_test.ts
index e1659b090..3484b7f81 100644
--- a/cli/tests/unit/wasm_test.ts
+++ b/cli/tests/unit/wasm_test.ts
@@ -77,6 +77,20 @@ Deno.test(async function wasmInstantiateStreaming() {
});
Deno.test(
+ { permissions: { read: true } },
+ async function wasmFileStreaming() {
+ const url = new URL("../testdata/unreachable.wasm", import.meta.url);
+ assert(url.href.startsWith("file://"));
+
+ const { module } = await WebAssembly.instantiateStreaming(fetch(url));
+ assertEquals(WebAssembly.Module.exports(module), [{
+ name: "unreachable",
+ kind: "function",
+ }]);
+ },
+);
+
+Deno.test(
{ permissions: { net: true } },
async function wasmStreamingNonTrivial() {
// deno-dom's WASM file is a real-world non-trivial case that gave us