From 3705a7e430f5ce8d9e47a87c8cae4cf0b2566120 Mon Sep 17 00:00:00 2001 From: Sean McArthur Date: Tue, 16 Apr 2024 08:25:09 -0400 Subject: [PATCH] Revert "fix(client): send content-length even with no body" This reverts commit 172fdfaf0e0d9222917f271a83339238082e2657. --- src/proto/h1/role.rs | 23 ++++++----------------- tests/client.rs | 24 ------------------------ 2 files changed, 6 insertions(+), 41 deletions(-) diff --git a/src/proto/h1/role.rs b/src/proto/h1/role.rs index cad25d1ab9..958340775a 100644 --- a/src/proto/h1/role.rs +++ b/src/proto/h1/role.rs @@ -1288,13 +1288,6 @@ impl Client { body } else { head.headers.remove(header::TRANSFER_ENCODING); - // If we know there's body coming, set a content-length. - // But only if the method normally has a body. - // GET, HEAD, and CONNECT are assumed empty. - if !is_method_assumed_empty(&head.subject.0) { - head.headers - .insert(header::CONTENT_LENGTH, HeaderValue::from_static("0")); - } return Encoder::length(0); }; @@ -1368,11 +1361,12 @@ impl Client { // So instead of sending a "chunked" body with a 0-chunk, // assume no body here. If you *must* send a body, // set the headers explicitly. - if is_method_assumed_empty(&head.subject.0) { - Some(Encoder::length(0)) - } else { - te.insert(HeaderValue::from_static("chunked")); - Some(Encoder::chunked()) + match head.subject.0 { + Method::GET | Method::HEAD | Method::CONNECT => Some(Encoder::length(0)), + _ => { + te.insert(HeaderValue::from_static("chunked")); + Some(Encoder::chunked()) + } } } else { None @@ -1474,11 +1468,6 @@ impl Client { } } -#[cfg(feature = "client")] -fn is_method_assumed_empty(method: &Method) -> bool { - matches!(method, &Method::GET | &Method::HEAD | &Method::CONNECT) -} - #[cfg(feature = "client")] fn set_content_length(headers: &mut HeaderMap, len: u64) -> Encoder { // At this point, there should not be a valid Content-Length diff --git a/tests/client.rs b/tests/client.rs index 73d080f3f7..43e1f08acb 100644 --- a/tests/client.rs +++ b/tests/client.rs @@ -888,30 +888,6 @@ test! { body: None, } -test! { - name: client_post_empty_auto_length, - - server: - expected: "\ - POST /empty HTTP/1.1\r\n\ - host: {addr}\r\n\ - content-length: 0\r\n\ - \r\n\ - ", - reply: REPLY_OK, - - client: - request: { - method: POST, - url: "http://{addr}/empty", - headers: {}, - }, - response: - status: OK, - headers: {}, - body: None, -} - test! { name: client_head_ignores_body,