Skip to content

Commit

Permalink
api: remove Future.Err()
Browse files Browse the repository at this point in the history
The method causes an improper error handling because it return an error
only from a client side. Therefore, it is not enough to simply check
the error to find out that the request was not completed.

A user should check an error from `Future.Get()` or
`Future.GetTyped()`. In addition, the user can find out whether there
was an error without decoding the response body with
`Future.GetResponse()`, see `ExampleErrorNo`.
  • Loading branch information
oleg-jukovec committed Feb 8, 2024
1 parent f33032e commit 2930086
Show file tree
Hide file tree
Showing 3 changed files with 4 additions and 8 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ Versioning](http://semver.org/spec/v2.0.0.html) except to the first release.
- `Schema` field from the `Connection` struct (#7)
- `OkCode` and `PushCode` constants (#237)
- SSL support (#301)
- `Future.Err()` method (#382)

### Fixed

Expand Down
3 changes: 3 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -348,6 +348,9 @@ for an `ops` field. `*Operations` needs to be used instead.
* `Future` constructors now accept `Request` as their argument.
* Methods `AppendPush` and `SetResponse` accepts response `Header` and data
as their arguments.
* Method `Err` removed because it provokes an invalid error checking. You need
to check an error from `Get`, `GetTyped` or `GetResponse` with an addition
check a value of `Response.Header().Error`.

#### Connector changes

Expand Down
8 changes: 0 additions & 8 deletions future.go
Original file line number Diff line number Diff line change
Expand Up @@ -266,11 +266,3 @@ func (fut *Future) WaitChan() <-chan struct{} {
}
return fut.done
}

// Err returns error set on Future.
// It waits for future to be set.
// Note: it doesn't decode body, therefore decoding error are not set here.
func (fut *Future) Err() error {
fut.wait()
return fut.err
}

0 comments on commit 2930086

Please sign in to comment.