Skip to content

dataconnect(chore): CoroutineUtils.kt added with function createSupervisorCoroutineScope()#8133

Merged
dconeybe merged 2 commits into
mainfrom
dconeybe/dataconnect/CreateSupervisorCoroutineScope
May 11, 2026
Merged

dataconnect(chore): CoroutineUtils.kt added with function createSupervisorCoroutineScope()#8133
dconeybe merged 2 commits into
mainfrom
dconeybe/dataconnect/CreateSupervisorCoroutineScope

Conversation

@dconeybe
Copy link
Copy Markdown
Contributor

No description provided.

…()` and code modified to use it, replacing bespoke scope creation logic
@gemini-code-assist
Copy link
Copy Markdown
Contributor

Using Gemini Code Assist

The 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 /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands on the current page.

Feature Command Description
Code Review /gemini review Performs a code review for the current pull request in its current state.
Pull Request Summary /gemini summary Provides a summary of the current pull request in its current state.
Comment @gemini-code-assist Responds in comments when explicitly tagged, both in pull request comments and review comments.
Help /gemini help Displays a list of available commands.

Customization

To customize the 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 .gemini/ folder in the base of the repository. Detailed instructions can be found here.

Limitations & Feedback

Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counterproductive. 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.

@dconeybe
Copy link
Copy Markdown
Contributor Author

/gemini review

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented May 10, 2026

📝 PRs merging into main branch

Our main branch should always be in a releasable state. If you are working on a larger change, or if you don't want this change to see the light of the day just yet, consider using a feature branch first, and only merge into the main branch when the code complete and ready to be released.

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request introduces a new utility function, createSupervisorCoroutineScope, to standardize the creation of coroutine scopes with supervisor jobs and exception handlers across several components, including DataConnectCredentialsTokenManager, FirebaseDataConnectImpl, LiveQuery, and DataConnectCacheDatabase. A logic error was identified in the CoroutineUtils implementation where CoroutineName is not unconditionally replaced as documented, which could cause child scopes to inherit parent names and complicate debugging.

…outineScope(), and fix the CoroutineName bug.

The "CoroutineName Bug" was identified by gemini code assist:

The implementation of CoroutineName assignment does not match the docstring and introduces a
regression in behavior. The docstring states that the CoroutineName will be unconditionally
replaced, but the current implementation only sets it if it is missing from the context. This
causes child scopes (like the one in DataConnectCredentialsTokenManager) to inherit the parent's
name instead of using their own instanceId, which can make debugging and log analysis more
difficult.
@dconeybe
Copy link
Copy Markdown
Contributor Author

/gemini review

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request introduces a centralized utility, createSupervisorCoroutineScope, to standardize the creation of coroutine scopes with supervisor jobs and consistent exception handling across the codebase. This utility is integrated into several classes, reducing boilerplate and ensuring uniform logging of uncaught exceptions. Review feedback highlights a slight regression in logging detail where the exception string is no longer explicitly appended to the log message, and notes the removal of a specific error code in FirebaseDataConnectImpl that might be useful for debugging.

@dconeybe dconeybe marked this pull request as ready for review May 10, 2026 23:13
@dconeybe dconeybe merged commit c6f1521 into main May 11, 2026
43 checks passed
@dconeybe dconeybe deleted the dconeybe/dataconnect/CreateSupervisorCoroutineScope branch May 11, 2026 19:18
@github-actions github-actions Bot mentioned this pull request May 12, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants