From 92443d7ef57ed474f0add7dd1f114c81a3faa8fe Mon Sep 17 00:00:00 2001 From: Sean McArthur Date: Thu, 2 Feb 2023 09:35:07 -0500 Subject: [PATCH] fix(server): prevent sending 100-continue if user drops request body (#3138) --- src/proto/h1/conn.rs | 6 ++++++ tests/server.rs | 3 +-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/proto/h1/conn.rs b/src/proto/h1/conn.rs index 37ab380f8b..5ebff2803e 100644 --- a/src/proto/h1/conn.rs +++ b/src/proto/h1/conn.rs @@ -748,6 +748,12 @@ where /// If the read side can be cheaply drained, do so. Otherwise, close. pub(super) fn poll_drain_or_close_read(&mut self, cx: &mut task::Context<'_>) { + if let Reading::Continue(ref decoder) = self.state.reading { + // skip sending the 100-continue + // just move forward to a read, in case a tiny body was included + self.state.reading = Reading::Body(decoder.clone()); + } + let _ = self.poll_read_body(cx); // If still in Reading::Body, just give up diff --git a/tests/server.rs b/tests/server.rs index af5b5e9961..017cca9405 100644 --- a/tests/server.rs +++ b/tests/server.rs @@ -973,9 +973,8 @@ async fn expect_continue_waits_for_body_poll() { service_fn(|req| { assert_eq!(req.headers()["expect"], "100-continue"); // But! We're never going to poll the body! + drop(req); tokio::time::sleep(Duration::from_millis(50)).map(move |_| { - // Move and drop the req, so we don't auto-close - drop(req); Response::builder() .status(StatusCode::BAD_REQUEST) .body(hyper::Body::empty())