Skip to content

Commit

Permalink
fix(bigquery/storage/managedwriter): faster context failure on send (g…
Browse files Browse the repository at this point in the history
…oogleapis#10169)

This is a minor PR that accelerates the failure loop for context expiration cases.  Previously, the connection abstraction would deal with expired context on the receiver side, and this change simply checks context before allowing a new append to succeed.

Tests already existed that exhibited this behavior, but were timing dependent and masked the issue (the receiver would close the connection fast enough).

Fixes: https://togithub.com/googleapis/google-cloud-go/issues/10128
  • Loading branch information
shollyman authored May 21, 2024
1 parent a495f8f commit 1fb0e64
Showing 1 changed file with 5 additions and 0 deletions.
5 changes: 5 additions & 0 deletions bigquery/storage/managedwriter/connection.go
Original file line number Diff line number Diff line change
Expand Up @@ -369,6 +369,11 @@ func (co *connection) lockingAppend(pw *pendingWrite) error {
}
}()

// If connection context is expired, error.
if err := co.ctx.Err(); err != nil {
return err
}

var arc *storagepb.BigQueryWrite_AppendRowsClient
var ch chan *pendingWrite
var err error
Expand Down

0 comments on commit 1fb0e64

Please sign in to comment.