mirror of
https://github.com/kennethreitz/langchain.git
synced 2026-06-05 23:00:18 +00:00
Callbacks Refactor [base] (#3256)
Co-authored-by: Nuno Campos <nuno@boringbits.io> Co-authored-by: Davis Chase <130488702+dev2049@users.noreply.github.com> Co-authored-by: Zander Chase <130414180+vowelparrot@users.noreply.github.com> Co-authored-by: Harrison Chase <hw.chase.17@gmail.com>
This commit is contained in:
@@ -0,0 +1,45 @@
|
||||
"""Test base tool child implementations."""
|
||||
|
||||
|
||||
import inspect
|
||||
import re
|
||||
from typing import List, Type
|
||||
|
||||
import pytest
|
||||
|
||||
from langchain.tools.base import BaseTool
|
||||
from langchain.tools.playwright.base import BaseBrowserTool
|
||||
|
||||
|
||||
def get_non_abstract_subclasses(cls: Type[BaseTool]) -> List[Type[BaseTool]]:
|
||||
to_skip = {BaseBrowserTool} # Abstract but not recognized
|
||||
subclasses = []
|
||||
for subclass in cls.__subclasses__():
|
||||
if (
|
||||
not getattr(subclass, "__abstract__", None)
|
||||
and not subclass.__name__.startswith("_")
|
||||
and subclass not in to_skip
|
||||
):
|
||||
subclasses.append(subclass)
|
||||
subclasses.extend(get_non_abstract_subclasses(subclass))
|
||||
return subclasses
|
||||
|
||||
|
||||
@pytest.mark.parametrize("cls", get_non_abstract_subclasses(BaseTool)) # type: ignore
|
||||
def test_all_subclasses_accept_run_manager(cls: Type[BaseTool]) -> None:
|
||||
"""Test that tools defined in this repo accept a run manager argument."""
|
||||
# This wouldn't be necessary if the BaseTool had a strict API.
|
||||
if cls._run is not BaseTool._arun:
|
||||
run_func = cls._run
|
||||
params = inspect.signature(run_func).parameters
|
||||
assert "run_manager" in params
|
||||
pattern = re.compile(r"(?!Async)CallbackManagerForToolRun")
|
||||
assert bool(re.search(pattern, str(params["run_manager"].annotation)))
|
||||
assert params["run_manager"].default is None
|
||||
|
||||
if cls._arun is not BaseTool._arun:
|
||||
run_func = cls._arun
|
||||
params = inspect.signature(run_func).parameters
|
||||
assert "run_manager" in params
|
||||
assert "AsyncCallbackManagerForToolRun" in str(params["run_manager"].annotation)
|
||||
assert params["run_manager"].default is None
|
||||
Reference in New Issue
Block a user