Refactor tests stylistically

pull/1187/head
Herman Slatman 1 year ago
parent 36da484604
commit b8c306ebfa
No known key found for this signature in database
GPG Key ID: F4D8A44EA0A75A4F

@ -21,6 +21,7 @@ type StackTracedError interface {
type fieldCarrier interface { type fieldCarrier interface {
WithFields(map[string]any) WithFields(map[string]any)
Fields() map[string]any
} }
// Error adds to the response writer the given error if it implements // Error adds to the response writer the given error if it implements

@ -1,8 +1,8 @@
package log package log
import ( import (
"net/http"
"net/http/httptest" "net/http/httptest"
"strconv"
"testing" "testing"
"unsafe" "unsafe"
@ -12,61 +12,68 @@ import (
"github.com/smallstep/certificates/logging" "github.com/smallstep/certificates/logging"
) )
type stackTracedError struct{}
func (stackTracedError) Error() string {
return "a stacktraced error"
}
func (stackTracedError) StackTrace() pkgerrors.StackTrace {
f := struct{}{}
return pkgerrors.StackTrace{ // fake stacktrace
pkgerrors.Frame(unsafe.Pointer(&f)),
pkgerrors.Frame(unsafe.Pointer(&f)),
}
}
func TestError(t *testing.T) { func TestError(t *testing.T) {
cases := []struct { tests := []struct {
name string
error error
rw http.ResponseWriter
isFieldCarrier bool
stepDebug bool stepDebug bool
expectStackTrace bool expectStackTrace bool
}{ }{
0: {nil, false, false}, {"noLogger", nil, nil, false, false, false},
1: {nil, true, false}, {"noError", nil, logging.NewResponseLogger(httptest.NewRecorder()), true, false, false},
2: {assert.AnError, false, false}, {"noErrorDebug", nil, logging.NewResponseLogger(httptest.NewRecorder()), true, true, false},
3: {assert.AnError, true, false}, {"anError", assert.AnError, logging.NewResponseLogger(httptest.NewRecorder()), true, false, false},
4: {new(stackTracedError), false, false}, {"anErrorDebug", assert.AnError, logging.NewResponseLogger(httptest.NewRecorder()), true, true, false},
5: {new(stackTracedError), true, true}, {"stackTracedError", new(stackTracedError), logging.NewResponseLogger(httptest.NewRecorder()), true, true, true},
{"stackTracedErrorDebug", new(stackTracedError), logging.NewResponseLogger(httptest.NewRecorder()), true, true, true},
} }
for caseIndex := range cases { for _, tt := range tests {
kase := cases[caseIndex] t.Run(tt.name, func(t *testing.T) {
if tt.stepDebug {
t.Run(strconv.Itoa(caseIndex), func(t *testing.T) {
if kase.stepDebug {
t.Setenv("STEPDEBUG", "1") t.Setenv("STEPDEBUG", "1")
} else { } else {
t.Setenv("STEPDEBUG", "0") t.Setenv("STEPDEBUG", "0")
} }
rw := logging.NewResponseLogger(httptest.NewRecorder()) Error(tt.rw, tt.error)
Error(rw, kase.error)
fields := rw.Fields() // return early if test case doesn't use logger
if !tt.isFieldCarrier {
return
}
// expect the error field to be set and to be the same error that was fed to Error fields := tt.rw.(logging.ResponseLogger).Fields()
if kase.error == nil {
// expect the error field to be (not) set and to be the same error that was fed to Error
if tt.error == nil {
assert.Nil(t, fields["error"]) assert.Nil(t, fields["error"])
} else { } else {
assert.Same(t, kase.error, fields["error"]) assert.Same(t, tt.error, fields["error"])
} }
if _, hasStackTrace := fields["stack-trace"]; kase.expectStackTrace && !hasStackTrace { // check if stack-trace is set when expected
t.Error("stack-trace was not set") if _, hasStackTrace := fields["stack-trace"]; tt.expectStackTrace && !hasStackTrace {
} else if !kase.expectStackTrace && hasStackTrace { t.Error(`ResponseLogger["stack-trace"] not set`)
t.Error("stack-trace was set") } else if !tt.expectStackTrace && hasStackTrace {
t.Error(`ResponseLogger["stack-trace"] was set`)
} }
}) })
} }
} }
type stackTracedError struct{}
func (stackTracedError) Error() string {
return "a stacktraced error"
}
func (stackTracedError) StackTrace() pkgerrors.StackTrace {
f := struct{}{}
return pkgerrors.StackTrace{ // fake stacktrace
pkgerrors.Frame(unsafe.Pointer(&f)),
pkgerrors.Frame(unsafe.Pointer(&f)),
}
}

Loading…
Cancel
Save