Commit aa42881e authored by Andrew Gerrand's avatar Andrew Gerrand

http: add test for panic inside hijacked request

R=golang-dev, rsc, rsc
CC=golang-dev
https://golang.org/cl/5283052
parent b1fd528d
...@@ -864,6 +864,14 @@ func TestZeroLengthPostAndResponse(t *testing.T) { ...@@ -864,6 +864,14 @@ func TestZeroLengthPostAndResponse(t *testing.T) {
} }
func TestHandlerPanic(t *testing.T) { func TestHandlerPanic(t *testing.T) {
testHandlerPanic(t, false)
}
func TestHandlerPanicWithHijack(t *testing.T) {
testHandlerPanic(t, true)
}
func testHandlerPanic(t *testing.T, withHijack bool) {
// Unlike the other tests that set the log output to ioutil.Discard // Unlike the other tests that set the log output to ioutil.Discard
// to quiet the output, this test uses a pipe. The pipe serves three // to quiet the output, this test uses a pipe. The pipe serves three
// purposes: // purposes:
...@@ -884,7 +892,14 @@ func TestHandlerPanic(t *testing.T) { ...@@ -884,7 +892,14 @@ func TestHandlerPanic(t *testing.T) {
log.SetOutput(pw) log.SetOutput(pw)
defer log.SetOutput(os.Stderr) defer log.SetOutput(os.Stderr)
ts := httptest.NewServer(HandlerFunc(func(ResponseWriter, *Request) { ts := httptest.NewServer(HandlerFunc(func(w ResponseWriter, r *Request) {
if withHijack {
rwc, _, err := w.(Hijacker).Hijack()
if err != nil {
t.Logf("unexpected error: %v", err)
}
defer rwc.Close()
}
panic("intentional death for testing") panic("intentional death for testing")
})) }))
defer ts.Close() defer ts.Close()
......
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