Commit 38ca0466 authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

net/http: fix flaky TestServerValidatesHostHeader

Passes with go test -race -count=1000 -name=TestServerValidatesHostHeader now
without hanging.

Fixes #13950

Change-Id: I41c3a555c642595c95c8c52f19a05a4c68e67630
Reviewed-on: https://go-review.googlesource.com/18660
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent efd93a41
...@@ -3827,7 +3827,7 @@ func TestServerValidatesHostHeader(t *testing.T) { ...@@ -3827,7 +3827,7 @@ func TestServerValidatesHostHeader(t *testing.T) {
{"HTTP/1.0", "Host: \xff\r\n", 400}, {"HTTP/1.0", "Host: \xff\r\n", 400},
} }
for _, tt := range tests { for _, tt := range tests {
conn := &testConn{closec: make(chan bool)} conn := &testConn{closec: make(chan bool, 1)}
io.WriteString(&conn.readBuf, "GET / "+tt.proto+"\r\n"+tt.host+"\r\n") io.WriteString(&conn.readBuf, "GET / "+tt.proto+"\r\n"+tt.host+"\r\n")
ln := &oneConnListener{conn} ln := &oneConnListener{conn}
...@@ -3867,7 +3867,7 @@ func TestServerValidatesHeaders(t *testing.T) { ...@@ -3867,7 +3867,7 @@ func TestServerValidatesHeaders(t *testing.T) {
{"foo: foo\xfffoo\r\n", 200}, // non-ASCII high octets in value are fine {"foo: foo\xfffoo\r\n", 200}, // non-ASCII high octets in value are fine
} }
for _, tt := range tests { for _, tt := range tests {
conn := &testConn{closec: make(chan bool)} conn := &testConn{closec: make(chan bool, 1)}
io.WriteString(&conn.readBuf, "GET / HTTP/1.1\r\nHost: foo\r\n"+tt.header+"\r\n") io.WriteString(&conn.readBuf, "GET / HTTP/1.1\r\nHost: foo\r\n"+tt.header+"\r\n")
ln := &oneConnListener{conn} ln := &oneConnListener{conn}
......
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