Commit 2f2423c8 authored by Emmanuel Odeke's avatar Emmanuel Odeke Committed by Brad Fitzpatrick

net/http: TimeoutHandler test ported to HTTP/2

Change-Id: I69e62199140e5cf203696af17d4816f3a5f13bd1
Reviewed-on: https://go-review.googlesource.com/17434
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 983926a7
...@@ -1654,7 +1654,10 @@ func TestRequestBodyTimeoutClosesConnection(t *testing.T) { ...@@ -1654,7 +1654,10 @@ func TestRequestBodyTimeoutClosesConnection(t *testing.T) {
} }
} }
func TestTimeoutHandler(t *testing.T) { func TestTimeoutHandler_h1(t *testing.T) { testTimeoutHandler(t, false) }
func TestTimeoutHandler_h2(t *testing.T) { testTimeoutHandler(t, true) }
func testTimeoutHandler(t *testing.T, h2 bool) {
defer afterTest(t) defer afterTest(t)
sendHi := make(chan bool, 1) sendHi := make(chan bool, 1)
writeErrors := make(chan error, 1) writeErrors := make(chan error, 1)
...@@ -1664,12 +1667,12 @@ func TestTimeoutHandler(t *testing.T) { ...@@ -1664,12 +1667,12 @@ func TestTimeoutHandler(t *testing.T) {
writeErrors <- werr writeErrors <- werr
}) })
timeout := make(chan time.Time, 1) // write to this to force timeouts timeout := make(chan time.Time, 1) // write to this to force timeouts
ts := httptest.NewServer(NewTestTimeoutHandler(sayHi, timeout)) cst := newClientServerTest(t, h2, NewTestTimeoutHandler(sayHi, timeout))
defer ts.Close() defer cst.close()
// Succeed without timing out: // Succeed without timing out:
sendHi <- true sendHi <- true
res, err := Get(ts.URL) res, err := cst.c.Get(cst.ts.URL)
if err != nil { if err != nil {
t.Error(err) t.Error(err)
} }
...@@ -1686,7 +1689,7 @@ func TestTimeoutHandler(t *testing.T) { ...@@ -1686,7 +1689,7 @@ func TestTimeoutHandler(t *testing.T) {
// Times out: // Times out:
timeout <- time.Time{} timeout <- time.Time{}
res, err = Get(ts.URL) res, err = cst.c.Get(cst.ts.URL)
if err != nil { if err != nil {
t.Error(err) t.Error(err)
} }
......
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