rikhuijzer opened PR #8085 from rikhuijzer:rh/wasi-http-timeout
to bytecodealliance:main
:
@elliottt in https://github.com/bytecodealliance/wasmtime/issues/7356 mentions that
connect_timeout
,first_byte_timeout
, andbetween_bytes_timeout
should be tested.This PR adds a test for
connect_timeout
and ensures thatTcpStream::connect
adheres to the timeout. Without this fix, settingconnect_timeout
has no effect on hosts whereTcpStream::connect
tries to connect.Note that the variable
connect_timeout
is also used a bit later for the handshake:I'm not sure whether using this variable twice is correct.
rikhuijzer requested alexcrichton for a review on PR #8085.
rikhuijzer requested wasmtime-core-reviewers for a review on PR #8085.
rikhuijzer updated PR #8085.
rikhuijzer updated PR #8085.
rikhuijzer updated PR #8085.
elliottt submitted PR review:
This looks great, thank you!
elliottt submitted PR review:
This looks great, thank you!
elliottt created PR review comment:
Thanks for matching the timeout explicitly here!
elliottt commented on PR #8085:
I'm not sure whether using this variable twice is correct.
I see two uses in the
handler
function, but they're under different branches of the same conditional. Was there another use ofconnect_timeout
that you were thinking of?
rikhuijzer commented on PR #8085:
This looks great, thank you!
Thanks for the review!
I'm not sure whether using this variable twice is correct.
I see two uses in the
handler
function, but they're under different branches of the same conditional. Was there another use ofconnect_timeout
that you were thinking of?There should be three (https://github.com/bytecodealliance/wasmtime/blob/eebce11eb1fdfc67ab8fc7a06cb68ba1231dd7a6/crates/wasi-http/src/types.rs).
One is now newly added near the
TcpStream::connect
and the other two are inside the branches nearhyper::client::conn::http1::handshake
. I think these two different phases represent TCP's SYN and ACK.Why I mentioned it is because it sounded a bit weird to me that the
connect_timeout
is used twice, but on second thought maybe it's fine. The SYN and ACK are both still during the "Connection establishment" phase.
elliottt commented on PR #8085:
Ah! Sorry for misunderstanding. I think this is fine to leave it this way, but I agree that it's a little odd. Reading through the handshake implementation, it's assuming that the connection has already been made, so if anything we might want to remove the timeout on the second two uses in the function.
elliottt commented on PR #8085:
I added #8104 to record the fact that we should look into removing the uses of
connect_timeout
on the handshake calls, but that issue won't be valid until this PR merges.
elliottt submitted PR review.
elliottt created PR review comment:
This check failed on the MinGW build. What do you think about removing it and adding it back in a follow-up PR? As an aside, you can add
prtest:mingw-x64
in a commit message to explicitly run that job.
rikhuijzer updated PR #8085.
elliottt merged PR #8085.
Last updated: Jan 24 2025 at 00:11 UTC