chore: avoid nested WithCodeResponseWriter (#3406)
This commit is contained in:
@@ -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
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user