Skip to content

Commit

Permalink
Merge pull request #4 from hostwithquantum/fix-errors
Browse files Browse the repository at this point in the history
Fix: error handling
  • Loading branch information
rwos authored Feb 9, 2024
2 parents 7b3c10f + bc40056 commit 5c83ac0
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 1 deletion.
8 changes: 8 additions & 0 deletions config.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,13 +95,17 @@ func parseErrorResponse(response *http.Response) error {
if err != nil {
return fmt.Errorf("decoding error while unpacking response: %s", err)
}
defer response.Body.Close()

var keep []error
for _, detail := range errorResp.Details {
keep = append(keep, fmt.Errorf(
"field: %s (%s): %s", detail.Field, detail.Violation, detail.Message,
))
}
if len(keep) == 0 {
return fmt.Errorf("error: %s (%d %s)", errorResp.Message, errorResp.Status, errorResp.Error)
}

return errors.Join(keep...)
}
Expand All @@ -112,11 +116,15 @@ func parseLegacyErrorResponse(response *http.Response) error {
if err != nil {
return fmt.Errorf("decoding error while unpacking response: %s", err)
}
defer response.Body.Close()

// potentially multiple issues returned from the LexOffice API
var keep []error
for _, issue := range errorResp.IssueList {
keep = append(keep, fmt.Errorf("key: %s (%s): %s", issue.Key, issue.Source, issue.Type))
}
if len(keep) == 0 {
return fmt.Errorf("something went wrong but unclear what (empty IssueList)")
}
return errors.Join(keep...)
}
61 changes: 60 additions & 1 deletion errors_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,18 +29,47 @@ func TestErrorResponse(t *testing.T) {
},
})
assert.Error(t, err)
assert.ErrorContains(t, err, "key: missing_entity (company.vatRegistrationId): validation_failure")
assert.ErrorContains(t, err, "key: missing_entity (company.taxNumber): validation_failure")
})

t.Run("errors=new", func(t *testing.T) {
_, err := lexOffice.AddInvoice(golexoffice.InvoiceBody{})
assert.Error(t, err)
assert.ErrorContains(t, err, "field: lineItems[0].unitPrice.taxRatePercentage (NOTNULL): darf nicht leer sein")
})

}

func TestErrorNoDetails(t *testing.T) {
server := errorMockNoDetails()
defer server.Close()

lexOffice := golexoffice.NewConfig("token", nil)
lexOffice.SetBaseUrl(server.URL)

t.Run("errors=legacy", func(t *testing.T) {
_, err := lexOffice.AddContact(golexoffice.ContactBody{
Company: &golexoffice.ContactBodyCompany{
Name: "company",
VatRegistrationId: "",
TaxNumber: "",
},
})
assert.Error(t, err)
assert.ErrorContains(t, err, "something went wrong")
})

t.Run("errors=new", func(t *testing.T) {
_, err := lexOffice.AddInvoice(golexoffice.InvoiceBody{})
assert.Error(t, err)
assert.ErrorContains(t, err, "Something else went wrong. (406 Not Acceptable)")
})
}

func errorMock() *httptest.Server {
return httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if r.URL.Path == "/v1/contacts" {
if r.URL.Path == "/v1/contacts/" {
w.WriteHeader(http.StatusBadRequest)
//nolint:errcheck
w.Write([]byte(`{
Expand Down Expand Up @@ -75,3 +104,33 @@ func errorMock() *httptest.Server {
w.WriteHeader(http.StatusNotFound)
}))
}

func errorMockNoDetails() *httptest.Server {
return httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if r.URL.Path == "/v1/contacts/" {
w.WriteHeader(http.StatusBadRequest)
// unclear if this can actually happen for these legacy errors
//nolint:errcheck
w.Write([]byte(`{
"requestId":"75d4dad6-6ccb-40fd-8c22-797f2d421d98",
"IssueList":[]
}`))
return
}
if r.URL.Path == "/v1/invoices" {
w.WriteHeader(http.StatusNotAcceptable)
// this *can* and *does* happen however (details is optional)
//nolint:errcheck
w.Write([]byte(`{
"timestamp": "2017-05-11T17:12:31.233+02:00",
"status": 406,
"error": "Not Acceptable",
"path": "/v1/invoices",
"traceId": "90d78d0777be",
"message": "Something else went wrong."
}`))
return
}
w.WriteHeader(http.StatusNotFound)
}))
}

0 comments on commit 5c83ac0

Please sign in to comment.