Add test that would make wait_for_capacity hang if it doesn't loop
This commit is contained in:
committed by
Sean McArthur
parent
87969c1f29
commit
e9e0f27b80
@@ -54,14 +54,14 @@ impl Future for WaitForCapacity {
|
|||||||
type Output = h2::SendStream<Bytes>;
|
type Output = h2::SendStream<Bytes>;
|
||||||
|
|
||||||
fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
|
fn poll(mut self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
|
||||||
let _ = ready!(self.stream().poll_capacity(cx)).unwrap();
|
loop {
|
||||||
|
let _ = ready!(self.stream().poll_capacity(cx)).unwrap();
|
||||||
|
|
||||||
let act = self.stream().capacity();
|
let act = self.stream().capacity();
|
||||||
|
|
||||||
if act >= self.target {
|
if act >= self.target {
|
||||||
return Poll::Ready(self.stream.take().unwrap().into());
|
return Poll::Ready(self.stream.take().unwrap().into());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Poll::Pending
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1561,3 +1561,53 @@ async fn data_padding() {
|
|||||||
|
|
||||||
join(srv, h2).await;
|
join(srv, h2).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[tokio::test]
|
||||||
|
async fn poll_capacity_after_send_data_and_reserve() {
|
||||||
|
h2_support::trace_init!();
|
||||||
|
let (io, mut srv) = mock::new();
|
||||||
|
|
||||||
|
let srv = async move {
|
||||||
|
let settings = srv
|
||||||
|
.assert_client_handshake_with_settings(frames::settings().initial_window_size(5))
|
||||||
|
.await;
|
||||||
|
assert_default_settings!(settings);
|
||||||
|
srv.recv_frame(frames::headers(1).request("POST", "https://www.example.com/"))
|
||||||
|
.await;
|
||||||
|
srv.send_frame(frames::headers(1).response(200)).await;
|
||||||
|
srv.recv_frame(frames::data(1, &b"abcde"[..])).await;
|
||||||
|
srv.send_frame(frames::window_update(1, 5)).await;
|
||||||
|
srv.recv_frame(frames::data(1, &b""[..]).eos()).await;
|
||||||
|
};
|
||||||
|
|
||||||
|
let h2 = async move {
|
||||||
|
let (mut client, mut h2) = client::handshake(io).await.unwrap();
|
||||||
|
let request = Request::builder()
|
||||||
|
.method(Method::POST)
|
||||||
|
.uri("https://www.example.com/")
|
||||||
|
.body(())
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
let (response, mut stream) = client.send_request(request, false).unwrap();
|
||||||
|
|
||||||
|
let response = h2.drive(response).await.unwrap();
|
||||||
|
assert_eq!(response.status(), StatusCode::OK);
|
||||||
|
|
||||||
|
stream.send_data("abcde".into(), false).unwrap();
|
||||||
|
|
||||||
|
stream.reserve_capacity(5);
|
||||||
|
|
||||||
|
// Initial window size was 5 so current capacity is 0 even if we just reserved.
|
||||||
|
assert_eq!(stream.capacity(), 0);
|
||||||
|
|
||||||
|
// The first call to `poll_capacity` in `wait_for_capacity` will return 0.
|
||||||
|
let mut stream = h2.drive(util::wait_for_capacity(stream, 5)).await;
|
||||||
|
|
||||||
|
stream.send_data("".into(), true).unwrap();
|
||||||
|
|
||||||
|
// Wait for the connection to close
|
||||||
|
h2.await.unwrap();
|
||||||
|
};
|
||||||
|
|
||||||
|
join(srv, h2).await;
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user