feat(spanner): add ClientContext support#13775
Conversation
Summary of ChangesHello @aseering, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed! This pull request introduces robust support for a Highlights
Changelog
Activity
Using Gemini Code AssistThe full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips. Invoking Gemini You can request assistance from Gemini at any point by creating a comment using either
Customization To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a Limitations & Feedback Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here. You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension. Footnotes
|
There was a problem hiding this comment.
Code Review
This pull request introduces support for ClientContext across the Spanner Go client, enabling features like Secure Parameters. The implementation is thorough, propagating the new context from client configuration down to individual requests. The addition of a comprehensive test suite in secure_parameters_test.go is excellent and covers a wide range of scenarios, ensuring the new functionality is well-tested.
I've identified a couple of areas for improvement in spanner/transaction.go to enhance code clarity and efficiency. Specifically, the createRequestOptions function can be optimized to avoid unnecessary allocations, and the logic for constructing request options within beginTransaction can be simplified. My detailed comments provide specific suggestions for these improvements. Overall, this is a solid contribution.
| if opts.txOptions.TransactionTag != "" { | ||
| request.RequestOptions = &sppb.RequestOptions{TransactionTag: opts.txOptions.TransactionTag} | ||
| } | ||
| ro := createRequestOptions(sppb.RequestOptions_PRIORITY_UNSPECIFIED, "", opts.txOptions.TransactionTag, opts.txOptions.ClientContext) | ||
| if ro != nil { | ||
| if request.RequestOptions == nil { | ||
| request.RequestOptions = ro | ||
| } else { | ||
| request.RequestOptions.ClientContext = ro.ClientContext | ||
| } | ||
| } |
There was a problem hiding this comment.
This logic for setting RequestOptions is a bit complex and can be simplified. The TransactionTag is handled in two places, which is confusing. You can replace this entire block with a single call to createRequestOptions.
request.RequestOptions = createRequestOptions(sppb.RequestOptions_PRIORITY_UNSPECIFIED, "", opts.txOptions.TransactionTag, opts.txOptions.ClientContext)PR created by the Librarian CLI to initialize a release. Merging this PR will auto trigger a release. Librarian Version: v1.0.0 Language Image: us-central1-docker.pkg.dev/cloud-sdk-librarian-prod/images-prod/librarian-go@sha256:19bb93e8f1f916c61b597db2bad65dc432f79baaabb210499d7d0e4ad1dffe29 <details><summary>spanner: 1.88.0</summary> ## [1.88.0](spanner/v1.87.0...spanner/v1.88.0) (2026-02-11) ### Features * Adding Send and Ack Mutation Support for Cloud Spanner Queue (#13616) ([1cf600d](1cf600d6)) * include cache updates into the ResultSet response (PiperOrigin-RevId: 865546011) ([6f31019](6f310199)) * add a ClientContext field to Spanner requests (PiperOrigin-RevId: 853323071) ([80379ed](80379edb)) * add Secure Parameters to the ClientContext (PiperOrigin-RevId: 853323071) ([80379ed](80379edb)) * PGNumeric implements Scanner and Valuer (#13722) ([85bc9db](85bc9dbf)) * support struct literal (#13766) ([b4a6f4c](b4a6f4c5)) * Exposing total CPU related fields in AutoscalingConfig (PiperOrigin-RevId: 845819318) ([db65e79](db65e792)) * add ClientContext support (#13775) ([e85d706](e85d7061)) ### Bug Fixes * disable config logging by default (#13478) ([ad19592](ad19592e)) * decode PG JSONB array to PGJsonB struct (#13602) ([d72d0f4](d72d0f45)) ### Performance Improvements * only create sessions if multiplexed sessions are disabled (#13477) ([e44e58f](e44e58f6)) ### Documentation * A comment for field `param_types` in message `.google.spanner.v1.PartitionQueryRequest` is changed (PiperOrigin-RevId: 865546011) ([6f31019](6f310199)) * A comment for field `transaction_tag` in message `.google.spanner.v1.RequestOptions` is changed (PiperOrigin-RevId: 865546011) ([6f31019](6f310199)) * A comment for field `commit_timestamp` in message `.google.spanner.v1.BatchWriteResponse` is changed (PiperOrigin-RevId: 865546011) ([6f31019](6f310199)) * A comment for field `params` in message `.google.spanner.v1.PartitionQueryRequest` is changed (PiperOrigin-RevId: 865546011) ([6f31019](6f310199)) * Update client side metrics and permission issues in README (#13491) ([ab56892](ab56892e)) * Update high_priority_cpu_utilization_percent in AutoscalingConfig to be Optional and clarify its behavior when not specified (PiperOrigin-RevId: 845819318) ([db65e79](db65e792)) </details>
Add support for the new ClientContext field to Spanner's Go Client.
This enables support for Secure Parameters, as well as other future features.