influxdb/http/errors_test.go

115 lines
3.0 KiB
Go

package http_test
import (
"context"
"encoding/json"
stderrors "errors"
"github.com/influxdata/influxdb/v2/kit/platform/errors"
"io"
"net/http/httptest"
"testing"
"github.com/google/go-cmp/cmp"
"github.com/influxdata/influxdb/v2/http"
kithttp "github.com/influxdata/influxdb/v2/kit/transport/http"
)
func TestCheckError(t *testing.T) {
for _, tt := range []struct {
name string
write func(w *httptest.ResponseRecorder)
want error
}{
{
name: "platform error",
write: func(w *httptest.ResponseRecorder) {
h := kithttp.ErrorHandler(0)
err := &errors.Error{
Msg: "expected",
Code: errors.EInvalid,
}
h.HandleHTTPError(context.Background(), err, w)
},
want: &errors.Error{
Msg: "expected",
Code: errors.EInvalid,
},
},
{
name: "text error",
write: func(w *httptest.ResponseRecorder) {
w.Header().Set("Content-Type", "text/plain")
w.WriteHeader(500)
_, _ = io.WriteString(w, "upstream timeout\n")
},
want: &errors.Error{
Code: errors.EInternal,
Err: stderrors.New("upstream timeout"),
},
},
{
name: "error with bad json",
write: func(w *httptest.ResponseRecorder) {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(500)
_, _ = io.WriteString(w, "upstream timeout\n")
},
want: &errors.Error{
Code: errors.EInternal,
Msg: `attempted to unmarshal error as JSON but failed: "invalid character 'u' looking for beginning of value"`,
Err: stderrors.New("upstream timeout"),
},
},
{
name: "error with no content-type (encoded as json - with code)",
write: func(w *httptest.ResponseRecorder) {
w.WriteHeader(500)
_, _ = io.WriteString(w, `{"error": "service unavailable", "code": "unavailable"}`)
},
want: &errors.Error{
Code: errors.EUnavailable,
Err: stderrors.New("service unavailable"),
},
},
{
name: "error with no content-type (encoded as json - no code)",
write: func(w *httptest.ResponseRecorder) {
w.WriteHeader(503)
_, _ = io.WriteString(w, `{"error": "service unavailable"}`)
},
want: &errors.Error{
Code: errors.EUnavailable,
Err: stderrors.New("service unavailable"),
},
},
{
name: "error with no content-type (not json encoded)",
write: func(w *httptest.ResponseRecorder) {
w.WriteHeader(503)
},
want: &errors.Error{
Code: errors.EUnavailable,
Msg: `attempted to unmarshal error as JSON but failed: "unexpected end of JSON input"`,
Err: stderrors.New(""),
},
},
} {
t.Run(tt.name, func(t *testing.T) {
w := httptest.NewRecorder()
tt.write(w)
resp := w.Result()
cmpopt := cmp.Transformer("error", func(e error) string {
if e, ok := e.(*errors.Error); ok {
out, _ := json.Marshal(e)
return string(out)
}
return e.Error()
})
if got, want := http.CheckError(resp), tt.want; !cmp.Equal(want, got, cmpopt) {
t.Fatalf("unexpected error -want/+got:\n%s", cmp.Diff(want, got, cmpopt))
}
})
}
}