|
|
|
@ -2,6 +2,7 @@ package handler
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"bytes"
|
|
|
|
|
"errors"
|
|
|
|
|
"io"
|
|
|
|
|
"net/http"
|
|
|
|
|
"net/http/httptest"
|
|
|
|
@ -88,18 +89,23 @@ func TestLogHandlerSlow(t *testing.T) {
|
|
|
|
|
func TestDetailedLogHandler_Hijack(t *testing.T) {
|
|
|
|
|
resp := httptest.NewRecorder()
|
|
|
|
|
writer := &detailLoggedResponseWriter{
|
|
|
|
|
writer: &response.WithCodeResponseWriter{
|
|
|
|
|
Writer: resp,
|
|
|
|
|
},
|
|
|
|
|
writer: response.NewWithCodeResponseWriter(resp),
|
|
|
|
|
}
|
|
|
|
|
assert.NotPanics(t, func() {
|
|
|
|
|
_, _, _ = writer.Hijack()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
writer = &detailLoggedResponseWriter{
|
|
|
|
|
writer: &response.WithCodeResponseWriter{
|
|
|
|
|
Writer: mockedHijackable{resp},
|
|
|
|
|
},
|
|
|
|
|
writer: response.NewWithCodeResponseWriter(resp),
|
|
|
|
|
}
|
|
|
|
|
assert.NotPanics(t, func() {
|
|
|
|
|
_, _, _ = writer.Hijack()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
writer = &detailLoggedResponseWriter{
|
|
|
|
|
writer: response.NewWithCodeResponseWriter(mockedHijackable{
|
|
|
|
|
ResponseRecorder: resp,
|
|
|
|
|
}),
|
|
|
|
|
}
|
|
|
|
|
assert.NotPanics(t, func() {
|
|
|
|
|
_, _, _ = writer.Hijack()
|
|
|
|
@ -133,6 +139,13 @@ func TestWrapStatusCodeWithColor(t *testing.T) {
|
|
|
|
|
assert.Equal(t, "503", wrapStatusCode(http.StatusServiceUnavailable))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestDumpRequest(t *testing.T) {
|
|
|
|
|
const errMsg = "error"
|
|
|
|
|
r := httptest.NewRequest(http.MethodGet, "http://localhost", http.NoBody)
|
|
|
|
|
r.Body = mockedReadCloser{errMsg: errMsg}
|
|
|
|
|
assert.Equal(t, errMsg, dumpRequest(r))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func BenchmarkLogHandler(b *testing.B) {
|
|
|
|
|
b.ReportAllocs()
|
|
|
|
|
|
|
|
|
@ -146,3 +159,15 @@ func BenchmarkLogHandler(b *testing.B) {
|
|
|
|
|
handler.ServeHTTP(resp, req)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type mockedReadCloser struct {
|
|
|
|
|
errMsg string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m mockedReadCloser) Read(p []byte) (n int, err error) {
|
|
|
|
|
return 0, errors.New(m.errMsg)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (m mockedReadCloser) Close() error {
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|