Stream: general

Topic: ✔ WASI preview2 and preview together


view this post on Zulip Daniel Vigovszky (May 25 2023 at 14:40):

Hi! This is my first message here, I hope I'm writing it in the right place. I am experimenting with using the latest WASI preview2 interfaces such as wasi-http from Rust, creating components and running them with wasmtime, using a custom host implementation of all these WASI interfaces. I ran into some tooling issues and I feel I'm close to the point of understanding what's going on but anyway I will describe the whole problem so maybe you can point out if I'm doing something different as it's intended to (I'm quite new to this whole world of WASM).

Contribute to WebAssembly/wasi-http development by creating an account on GitHub.

view this post on Zulip Daniel Vigovszky (May 25 2023 at 14:51):

So what I'm trying to do is using Rust (1.69), and latest cargo componentto build the component. Using the preview1 adapter I can create components using some subset of the preview2 interfaces by mapping Rust's preview1 based std lib implementation. What I have trouble with is using some of the new interfaces, let's say wasi-http. To do so, I was using wit-deps to add the WITs to the project as dependencies (wasi-http and all its transitive depencencies). Then I'm importing the outgoing-http interface in my top level WIT so the binding generator generates code for it and I can use it in my implementation. This all works fine and compiles, but then in the step of creating the component from the core module, I get errors of merging WIT interfaces.

The error is the following:

error: failed merge WIT package sets together

Caused by:
  failed to merge WIT package sets together

Caused by:
  failed to merge package `http` into existing copy

Caused by:
  failed to merge document `types` into existing copy

Caused by:
  failed to merge interface `types`

Caused by:
  expected function `incoming-request-path-with-query` to be present

Later I realized if I'm doing it "by hand" (not via cargo-component but compiling to a core wasm module and running wasm-toolsmyself) then I get a bit more info, it says it fails to merge the preview1 adapter module.

For a long time I did not understand where could a different types interface coming in the picture. I even renamed the types interface in wasi-filesystem to see if that is colliding somehow with the one from wasi-http. (That did not help).

I also have a trace output from wasm-tools but that's also not very helpful
(Ends with:

[2023-05-25T11:18:36Z TRACE] merging duplicate package http / Some("path:/http")
error: failed to merge WIT packages of adapter `wasi_snapshot_preview1` into main packages

Caused by:
    0: failed to merge package `http` into existing copy
    1: failed to merge document `types` into existing copy
    2: failed to merge interface `types`
    3: expected function `incoming-request-path` to be present

)

After all this I think I realized that there is an other version of the WASI WIT documents in some binary form embedded as custom sections in the preview1 module, and that must be in conflict with the one I'm bringing in. Probably just an older version as the incoming-request-path mentioned in the error was changed to incoming-request-path-and-query I think.

So the question is how can I fix this? Should I build a preview1 adapter for myself using the latest WIT packages? Or am I doing something else wrong?

view this post on Zulip Lann Martin (May 25 2023 at 15:26):

You are spot on with the reason; the conflicting types are coming from here: https://github.com/bytecodealliance/preview2-prototyping/tree/main/wit/deps/http
A previous conversation on this topic: https://bytecodealliance.zulipchat.com/#narrow/stream/327223-wit-bindgen/topic/dependency.20namespacing

Polyfill adapter for preview1-using wasm modules to call preview2 functions. - preview2-prototyping/wit/deps/http at main · bytecodealliance/preview2-prototyping

view this post on Zulip Daniel Vigovszky (May 25 2023 at 15:46):

Thanks for the link! Indeed by using the older WITs that are in the adapter module everywhere the merging error is gone. (Now I'm having a linking error on the host but that's another story to figure out). That said, I think the wasi-http implementation in wasmtime is already using the newer version of the interface not the one in the adapter module. I understand everything is very much work in progress. If there is any way I can contribute to improve this situation please let me know!

view this post on Zulip Peter Huene (May 25 2023 at 16:58):

It sounds like, at a minimum, the adapters built into cargo-component are pretty out of date, I can do an update to latest

view this post on Zulip Peter Huene (May 25 2023 at 19:48):

Given we've just merged a change to the binary encoding of components, I'm going to hold off on updating cargo-component until wit-bindgen and the WASI adapaters have been updated

view this post on Zulip Pat Hickey (May 25 2023 at 23:49):

the wasmtime-wasi-http implementation isnt set up to work correctly with the wasmtime-wasi::preview2 implementation yet

view this post on Zulip Pat Hickey (May 25 2023 at 23:49):

so even when these other issues are resolved, there are still some hurdles to overcome to use wasi-http in wasmtime

view this post on Zulip Pat Hickey (May 25 2023 at 23:50):

im working on that soon

view this post on Zulip Notification Bot (May 30 2023 at 10:39):

Daniel Vigovszky has marked this topic as resolved.


Last updated: Jan 24 2025 at 00:11 UTC