joellubi commented on code in PR #38385: URL: https://github.com/apache/arrow/pull/38385#discussion_r1529368725
########## go/arrow/flight/flightsql/client.go: ########## @@ -218,6 +218,58 @@ func (c *Client) ExecuteSubstraitUpdate(ctx context.Context, plan SubstraitPlan, return updateResult.GetRecordCount(), nil } +var ErrTooManyPutResults = fmt.Errorf("%w: server sent multiple PutResults, expected one ", arrow.ErrInvalid) + +// ExecuteIngest is for executing a bulk ingestion and only returns the number of affected rows. +func (c *Client) ExecuteIngest(ctx context.Context, rdr array.RecordReader, reqOptions *ExecuteIngestOpts, opts ...grpc.CallOption) (n int64, err error) { + var ( + desc *flight.FlightDescriptor + stream pb.FlightService_DoPutClient + wr *flight.Writer + res *pb.PutResult + updateResult pb.DoPutUpdateResult + ) + + cmd := (*pb.CommandStatementIngest)(reqOptions) + if desc, err = descForCommand(cmd); err != nil { + return + } + + if stream, err = c.Client.DoPut(ctx, opts...); err != nil { + return + } + + wr = flight.NewRecordWriter(stream, ipc.WithAllocator(c.Alloc), ipc.WithSchema(rdr.Schema())) + defer wr.Close() + + wr.SetFlightDescriptor(desc) + + for rdr.Next() { + rec := rdr.Record() + wr.Write(rec) + } + Review Comment: Just a heads up: I expanded the testing to check some trickier scenarios like if the server returned an error mid-DoPut stream. Between this and handling some other flaky test failures, the error handling has been changed/improved quite a bit again. Just in case you wanted to review again. -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: github-unsubscr...@arrow.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org