Commit 9c2f4102 authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

net/http: don't send chunked encoding on 204 responses

RFC 2616: "The 204 response MUST NOT include a message-body,
and thus is always terminated by the first empty line after
the header fields."

Previously we'd trigger chunked encoding by default on
responses, and then when finishing the request we'd write the
chunk trailers, which counted as a message-body.

Fixes #4454

R=golang-dev
CC=golang-dev
https://golang.org/cl/6782139
parent 85e451e2
...@@ -369,6 +369,8 @@ func (w *response) WriteHeader(code int) { ...@@ -369,6 +369,8 @@ func (w *response) WriteHeader(code int) {
if w.req.Method == "HEAD" || code == StatusNotModified { if w.req.Method == "HEAD" || code == StatusNotModified {
// do nothing // do nothing
} else if code == StatusNoContent {
w.header.Del("Transfer-Encoding")
} else if hasCL { } else if hasCL {
w.contentLength = contentLength w.contentLength = contentLength
w.header.Del("Transfer-Encoding") w.header.Del("Transfer-Encoding")
......
...@@ -857,6 +857,30 @@ func TestIssue3595(t *testing.T) { ...@@ -857,6 +857,30 @@ func TestIssue3595(t *testing.T) {
} }
} }
// From http://golang.org/issue/4454 ,
// "client fails to handle requests with no body and chunked encoding"
func TestChunkedNoContent(t *testing.T) {
ts := httptest.NewServer(HandlerFunc(func(w ResponseWriter, r *Request) {
w.WriteHeader(StatusNoContent)
}))
defer ts.Close()
for _, closeBody := range []bool{true, false} {
c := &Client{Transport: &Transport{}}
const n = 4
for i := 1; i <= n; i++ {
res, err := c.Get(ts.URL)
if err != nil {
t.Errorf("closingBody=%v, req %d/%d: %v", closeBody, i, n, err)
} else {
if closeBody {
res.Body.Close()
}
}
}
}
}
func TestTransportConcurrency(t *testing.T) { func TestTransportConcurrency(t *testing.T) {
const maxProcs = 16 const maxProcs = 16
const numReqs = 500 const numReqs = 500
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment