Skip to content

Commit

Permalink
Return full errors
Browse files Browse the repository at this point in the history
  • Loading branch information
HaraldNordgren committed Dec 2, 2024
1 parent d3e516b commit 565c633
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 20 deletions.
13 changes: 12 additions & 1 deletion graphql/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -265,9 +265,20 @@ func (c *client) MakeRequest(ctx context.Context, req *Request, resp *Response)
if err != nil {
respBody = []byte(fmt.Sprintf("<unreadable: %v>", err))
}

var gqlResp Response
if err := json.Unmarshal(respBody, &gqlResp); err != nil {

Check failure on line 270 in graphql/client.go

View workflow job for this annotation

GitHub Actions / Lint

shadow: declaration of "err" shadows declaration at line 240 (govet)
return &HTTPError{
StatusCode: httpResp.StatusCode,
Body: Response{
Errors: gqlerror.List{&gqlerror.Error{Message: string(respBody)}},
},
}
}

return &HTTPError{
StatusCode: httpResp.StatusCode,
Body: string(respBody),
Body: gqlResp,
}
}

Expand Down
73 changes: 55 additions & 18 deletions graphql/client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,44 +9,82 @@ import (
"testing"

"github.com/stretchr/testify/assert"
"github.com/vektah/gqlparser/v2/gqlerror"
)

func TestMakeRequest_HTTPError(t *testing.T) {
testCases := []struct {

Check failure on line 16 in graphql/client_test.go

View workflow job for this annotation

GitHub Actions / Lint

fieldalignment: struct with 48 pointer bytes could be 32 (govet)
name string
serverResponseBody string
expectedErrorBody string
serverResponseCode int
expectedStatusCode int
serverResponseBody any
expectedError *HTTPError
}{
{
name: "400 Bad Request",
serverResponseBody: "Bad Request",
expectedErrorBody: "Bad Request",
name: "plain_text_error",
serverResponseCode: http.StatusBadRequest,
expectedStatusCode: http.StatusBadRequest,
serverResponseBody: "Bad Request",
expectedError: &HTTPError{
Body: Response{
Errors: gqlerror.List{
&gqlerror.Error{
Message: "\"Bad Request\"\n",
},
},
},
StatusCode: http.StatusBadRequest,
},
},
{
name: "429 Too Many Requests",
serverResponseBody: "Rate limit exceeded",
expectedErrorBody: "Rate limit exceeded",
name: "json_error_with_extensions",
serverResponseCode: http.StatusTooManyRequests,
expectedStatusCode: http.StatusTooManyRequests,
serverResponseBody: Response{
Errors: gqlerror.List{
&gqlerror.Error{
Message: "Rate limit exceeded",
Extensions: map[string]interface{}{
"code": "RATE_LIMIT_EXCEEDED",
},
},
},
},
expectedError: &HTTPError{
Body: Response{
Errors: gqlerror.List{
&gqlerror.Error{
Message: "Rate limit exceeded",
Extensions: map[string]interface{}{
"code": "RATE_LIMIT_EXCEEDED",
},
},
},
},
StatusCode: http.StatusTooManyRequests,
},
},
{
name: "500 Internal Server Error",
serverResponseBody: "Internal Server Error",
expectedErrorBody: "Internal Server Error",
name: "json_error_without_extensions",
serverResponseCode: http.StatusInternalServerError,
expectedStatusCode: http.StatusInternalServerError,
serverResponseBody: Response{
Errors: gqlerror.List{
&gqlerror.Error{Message: "Internal Server Error"},
},
},
expectedError: &HTTPError{
Body: Response{
Errors: gqlerror.List{
&gqlerror.Error{Message: "Internal Server Error"},
},
},
StatusCode: http.StatusInternalServerError,
},
},
}

for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(tc.serverResponseCode)
_, err := w.Write([]byte(tc.serverResponseBody))
err := json.NewEncoder(w).Encode(tc.serverResponseBody)
if err != nil {
t.Fatalf("Failed to write response: %v", err)
}
Expand All @@ -64,8 +102,7 @@ func TestMakeRequest_HTTPError(t *testing.T) {
assert.Error(t, err)
var httpErr *HTTPError
assert.True(t, errors.As(err, &httpErr), "Error should be of type *HTTPError")
assert.Equal(t, tc.expectedStatusCode, httpErr.StatusCode)
assert.Equal(t, tc.expectedErrorBody, httpErr.Body)
assert.Equal(t, tc.expectedError, httpErr)
})
}
}
Expand Down
2 changes: 1 addition & 1 deletion graphql/errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import "fmt"

// HTTPError represents an HTTP error with status code and response body.
type HTTPError struct {
Body string
Body Response
StatusCode int
}

Expand Down

0 comments on commit 565c633

Please sign in to comment.