From da322848a077812e336674e7fe9d9fbdb96fc921 Mon Sep 17 00:00:00 2001 From: Shawn Smith Date: Mon, 20 Mar 2023 14:43:15 +0900 Subject: [PATCH 1/2] return full error response if error JSON does not contain "message" field --- api.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/api.go b/api.go index c5b8c2e..e0f46f9 100644 --- a/api.go +++ b/api.go @@ -151,6 +151,12 @@ func errMsg(b []byte) error { return err } + // if error response does not contain "message" field, + // return the full error JSON + if errResp.Message == "" { + return errors.New(string(b)) + } + return errors.New(errResp.Message) } From ef112c71762480f484ffc15c62b265f305c04701 Mon Sep 17 00:00:00 2001 From: Shawn Smith Date: Mon, 20 Mar 2023 14:48:34 +0900 Subject: [PATCH 2/2] add TestErrMsg --- api_test.go | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/api_test.go b/api_test.go index 9c86186..730c6a2 100644 --- a/api_test.go +++ b/api_test.go @@ -1864,3 +1864,19 @@ func TestCRUDSiteRequestRule(t *testing.T) { t.Fatal(err) } } + +func TestErrMsg(t *testing.T) { + cases := []struct { + in []byte + want string + }{ + {[]byte(`{"message": "an error message"}`), "an error message"}, + {[]byte(`{"detail": "an error message"}`), `{"detail": "an error message"}`}, + } + + for _, tt := range cases { + if err := errMsg(tt.in); err.Error() != tt.want { + t.Errorf("got error message = %q, want %q", err.Error(), tt.want) + } + } +}