mirror of https://github.com/jackc/pgx.git
Fix error when using BatchResults.Exec
...on a select that returns an error after some rows. This was initially found in by a failure with CockroachDB because it seems to send a RowDescription before an error even when no rows are returned. PostgreSQL doesn't.pull/1579/head
parent
a23a423f55
commit
6defa2a607
5
batch.go
5
batch.go
|
@ -139,7 +139,10 @@ func (br *batchResults) Exec() (pgconn.CommandTag, error) {
|
|||
}
|
||||
|
||||
commandTag, err := br.mrr.ResultReader().Close()
|
||||
br.err = err
|
||||
if err != nil {
|
||||
br.err = err
|
||||
br.mrr.Close()
|
||||
}
|
||||
|
||||
if br.conn.batchTracer != nil {
|
||||
br.conn.batchTracer.TraceBatchQuery(br.ctx, br.conn, TraceBatchQueryData{
|
||||
|
|
|
@ -742,6 +742,27 @@ func TestSendBatchErrorWhileReadingResultsWithoutCallback(t *testing.T) {
|
|||
})
|
||||
}
|
||||
|
||||
func TestSendBatchErrorWhileReadingResultsWithExecWhereSomeRowsAreReturned(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
pgxtest.RunWithQueryExecModes(context.Background(), t, defaultConnTestRunner, nil, func(ctx context.Context, t testing.TB, conn *pgx.Conn) {
|
||||
batch := &pgx.Batch{}
|
||||
batch.Queue("select 4 / n from generate_series(-2, 2) n")
|
||||
|
||||
batchResult := conn.SendBatch(ctx, batch)
|
||||
|
||||
_, execErr := batchResult.Exec()
|
||||
require.Error(t, execErr)
|
||||
|
||||
closeErr := batchResult.Close()
|
||||
require.Equal(t, execErr, closeErr)
|
||||
|
||||
// Try to use the connection.
|
||||
_, err := conn.Exec(ctx, "select 1")
|
||||
require.NoError(t, err)
|
||||
})
|
||||
}
|
||||
|
||||
func TestConnBeginBatchDeferredError(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
|
|
Loading…
Reference in New Issue