core: fix for BaseTool when args_schema has pydantic validators that change the input keys #30004
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description:
We encountered a bug where we used a pydantic validator to patch broken llm inputs to our tools. The validator would fix the input dict, but the BaseTool would return an empty dict to the tool because our validator changed the dictionary keys. This PR changes one line of code to fix the issue and adds a test to improve the test coverage.
Concretely, the following code would fail before the PR:
Add tests and docs:
I added a test for the above use case.
Comments:
Please note that I had to remove
*args: Any
from one of the tests. The previous code would filter out theargs
keyword. I don't see any realistic use case where one would have*args
in their tool as this gives no meaningful instruction to the LLM on how to use the*args
. Please let me know if you see any issues here. I don't see a clean and robust method that would have the new test passing while still filtering out the*args
argument. Let me know if you see a better solution.