1
0
mirror of https://github.com/interviewstreet/go-jira.git synced 2025-06-16 23:47:50 +02:00

Fixed null pointer when no response is received

* JiraError can now handle nil responses
* Better error handling when the response is not JSON
This commit is contained in:
Bob Briski
2017-11-14 17:57:26 -08:00
parent 8686d2a5e0
commit 67d3f9b9ef
2 changed files with 38 additions and 1 deletions

View File

@ -19,6 +19,10 @@ type Error struct {
// NewJiraError creates a new jira Error
func NewJiraError(resp *Response, httpError error) error {
if resp == nil {
return errors.Wrap(httpError, "No response returned")
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
@ -28,7 +32,8 @@ func NewJiraError(resp *Response, httpError error) error {
jerr := Error{HTTPError: httpError}
err = json.Unmarshal(body, &jerr)
if err != nil {
return errors.Wrap(err, err.Error())
httpError = errors.Wrap(errors.New("Could not parse JSON"), httpError.Error())
return errors.Wrap(err, httpError.Error())
}
return &jerr