From 53c468062dcbcce3d44d6c031e3cb31292ffcc31 Mon Sep 17 00:00:00 2001 From: Rekha Mittal Date: Tue, 19 Mar 2019 11:27:47 -0700 Subject: [PATCH] Fix panic for unauthorized response with nil error --- error.go | 3 +++ error_test.go | 19 +++++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/error.go b/error.go index 16c85a8c..bd1a5b9a 100644 --- a/error.go +++ b/error.go @@ -38,6 +38,9 @@ func NewJiraError(resp *Response, httpError error) error { return errors.Wrap(err, httpError.Error()) } } else { + if httpError == nil { + return fmt.Errorf("Got Response Status %s:%s", resp.Status, string(body)) + } return errors.Wrap(httpError, fmt.Sprintf("%s: %s", resp.Status, string(body))) } diff --git a/error_test.go b/error_test.go index 51a2060d..f010ee09 100644 --- a/error_test.go +++ b/error_test.go @@ -62,6 +62,25 @@ func TestError_NoJSON(t *testing.T) { } } +func TestError_Unauthorized_NilError(t *testing.T) { + setup() + defer teardown() + + testMux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { + w.WriteHeader(http.StatusUnauthorized) + fmt.Fprint(w, `User is not authorized`) + }) + + req, _ := testClient.NewRequest("GET", "/", nil) + resp, _ := testClient.Do(req, nil) + + err := NewJiraError(resp, nil) + msg := err.Error() + if !strings.Contains(msg, "401 Unauthorized:User is not authorized") { + t.Errorf("Expected Unauthorized HTTP status: Got\n%s\n", msg) + } +} + func TestError_BadJSON(t *testing.T) { setup() defer teardown()