test_tool_retry_async_backoff_timing() — langchain Function Reference
Architecture documentation for the test_tool_retry_async_backoff_timing() function in test_tool_retry.py from the langchain codebase.
Entity Profile
Dependency Diagram
graph TD 587ae552_2524_ace4_f582_b693c8abb2c2["test_tool_retry_async_backoff_timing()"] c71b26df_821f_59ac_c7ef_3b96fcbe0d5b["test_tool_retry.py"] 587ae552_2524_ace4_f582_b693c8abb2c2 -->|defined in| c71b26df_821f_59ac_c7ef_3b96fcbe0d5b style 587ae552_2524_ace4_f582_b693c8abb2c2 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
libs/langchain_v1/tests/unit_tests/agents/middleware/implementations/test_tool_retry.py lines 790–831
async def test_tool_retry_async_backoff_timing() -> None:
"""Test ToolRetryMiddlewareasync applies correct backoff delays."""
temp_fail = TemporaryFailureTool(fail_count=3)
@tool
def temp_failing_tool(value: str) -> str:
"""Tool that fails temporarily."""
return temp_fail(value)
model = FakeToolCallingModel(
tool_calls=[
[ToolCall(name="temp_failing_tool", args={"value": "test"}, id="1")],
[],
]
)
retry = ToolRetryMiddleware(
max_retries=3,
initial_delay=0.1,
backoff_factor=2.0,
jitter=False,
)
agent = create_agent(
model=model,
tools=[temp_failing_tool],
middleware=[retry],
checkpointer=InMemorySaver(),
)
start_time = time.time()
result = await agent.ainvoke(
{"messages": [HumanMessage("Use temp failing tool")]},
{"configurable": {"thread_id": "test"}},
)
elapsed = time.time() - start_time
tool_messages = [m for m in result["messages"] if isinstance(m, ToolMessage)]
assert len(tool_messages) == 1
# Expected delays: 0.1 + 0.2 + 0.4 = 0.7 seconds
assert elapsed >= 0.6, f"Expected at least 0.6s, got {elapsed}s"
Domain
Subdomains
Source
Frequently Asked Questions
What does test_tool_retry_async_backoff_timing() do?
test_tool_retry_async_backoff_timing() is a function in the langchain codebase, defined in libs/langchain_v1/tests/unit_tests/agents/middleware/implementations/test_tool_retry.py.
Where is test_tool_retry_async_backoff_timing() defined?
test_tool_retry_async_backoff_timing() is defined in libs/langchain_v1/tests/unit_tests/agents/middleware/implementations/test_tool_retry.py at line 790.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free