fix: Type soundness issue with Provider.resolveObjectEvaluation #1158#1361
fix: Type soundness issue with Provider.resolveObjectEvaluation #1158#1361ScottVenkataraman wants to merge 2 commits intoopen-feature:mainfrom
Conversation
Summary of ChangesHello, 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 addresses a type soundness issue within the 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 correctly addresses a type soundness issue in resolveObjectEvaluation by using JsonValue for the default value and return type. However, this is a breaking change for the Provider interface, and the pull request is incomplete as it doesn't update the implementing classes like InMemoryProvider and MultiProvider. This will cause compilation errors. Please update all implementations of the Provider interface. I have also left a comment with a suggestion to further improve the new interface signature by removing a now-unused generic parameter.
This PR
Updates the TypeScript method signature of
resolveObjectEvaluationso that thedefaultValuehas a type ofJsonValueand the returned promise'sResolutionDetailshas a type ofJsonValue