You are viewing a plain text version of this content. The canonical link for it is here.
Posted to jira@arrow.apache.org by "ASF GitHub Bot (Jira)" <ji...@apache.org> on 2021/11/18 14:29:00 UTC
[jira] [Updated] (ARROW-14769) [Go] Errors from MessageReader.Message don't get surfaced by Reader.Read
[ https://issues.apache.org/jira/browse/ARROW-14769?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
ASF GitHub Bot updated ARROW-14769:
-----------------------------------
Labels: pull-request-available (was: )
> [Go] Errors from MessageReader.Message don't get surfaced by Reader.Read
> ------------------------------------------------------------------------
>
> Key: ARROW-14769
> URL: https://issues.apache.org/jira/browse/ARROW-14769
> Project: Apache Arrow
> Issue Type: Bug
> Components: Go
> Reporter: David Li
> Assignee: David Li
> Priority: Major
> Labels: pull-request-available
> Time Spent: 10m
> Remaining Estimate: 0h
>
> Noticed while playing with a Flight client. This snippet inadvertently suppresses all errors that come from the underlying MessageReader since {{next}} sets {{done}} after an error is encountered.
> {code:go}
> func (r *Reader) Read() (array.Record, error) {
> if r.rec != nil {
> r.rec.Release()
> r.rec = nil
> }
> if !r.next() {
> // r.done is set if next() errors, so we always
> // return EOF instead of the actual error
> if r.done {
> return nil, io.EOF
> }
> return nil, r.err
> }
> return r.rec, nil
> }{code}
--
This message was sent by Atlassian Jira
(v8.20.1#820001)