-
Notifications
You must be signed in to change notification settings - Fork 115
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support for Go 1.13 Error Wrapping #86
Comments
https://github.com/gofrs/uuid/blob/master/codec.go#L117 does not use error wrapping as my example above. |
Wait sorry i mixed up what repo i was looking at oops. |
So what do you think @jaddr2line is it worth me working in a PR for it? |
@krak3n I think this could be an interesting idea, but before expanding the API I'd love to understand how these errors could be handled. At least for the one provided, if the input is invalid there really isn't a way to handle that beyond logging or presenting it to the end user. |
@theckman indeed and ultimately if the end-user is just printing You can see this happening more in the standard library as support for Let's say for example I've written a HTTP API that takes some JSON as it's input, one of the attributes on the JSON is a UUID but the user fills in a bad UUID so type Request struct {
ID uuid.UUID `json:"id"`
}
func Handler(w http.ResponseWriter, r *http.Request) {
b, _ := ioutil.ReadAll(r.Body) // omitting error handling
var req Request
if err := json.Unmarshal(b, &req); err != nil {
switch {
case errors.Is(err, uuid.ErrIncorrectLength):
w.WriteHeader(http.StatusUnprocessableEntity)
w.Write([]byte(fmt.Sprintf("invalid uuid: %s". err)))
case errors.Is(err, ErrSomeOther):
w.WriteHeader(http.StatusBadRequest)
default:
w.WriteHeader(http.StatusInternalServerError)
}
}
// Continue as normal
} This pattern also allows for better error testing, instead of comparing error strings or asserting that an error is returned we can check the error is what we expect: id,err := FromString("foo")
if !errors.Is(err, ErrIncorrectLength) {
t.Errorf("want %v got %v", ErrIncorrectLength, err)
} This also allows for self-documenting errors, users can now see what errors this package can return and choose how to handle them, or not. |
I use error wrapping all the time to recognize specific errors. What if I am working on a website and this error is returned from your library? Right now I need to search the error text for specific strings to decide if it's this error since I can't match a single static string, and it could get worse as the error is wrapped with other text at other levels. However, if I can check if it's this specific error, I know it's a 400, not a 500. The expansion of the API is minor. You'd be returning something implementing the same error interface as before, and there would be no breaking changes to any code. |
I would be in favor of this change! |
Sill willing to work on this if everyone is up for it 👍 |
This is closed with #131 😃 Thanks for the suggestion! |
Hi
I was wondering if you had any interest in support for go1.13 error wrapping? For example:
This would allow for the usage of
errors.Is()
anderrors.As()
, useful for testing or performing other conditional logic based on the type of error, for example:If you approve I'd be more than happy to open a PR with the implementation detail.If backwards compatibility is a concern we can probably get around it with build tags.
Demo over on the playground: https://play.golang.org/p/H5teBSdvfct
The text was updated successfully, but these errors were encountered: