mirror of
https://github.com/hwchase17/langchain.git
synced 2025-09-10 23:41:28 +00:00
use output parsers in agents (#2987)
This commit is contained in:
@@ -37,7 +37,7 @@ def _get_agent(**kwargs: Any) -> AgentExecutor:
|
||||
bad_action_name = "BadAction"
|
||||
responses = [
|
||||
f"I'm turning evil\nAction: {bad_action_name}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses)
|
||||
tools = [
|
||||
@@ -92,7 +92,7 @@ def test_agent_with_callbacks_global() -> None:
|
||||
tool = "Search"
|
||||
responses = [
|
||||
f"FooBarBaz\nAction: {tool}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses, callback_manager=manager, verbose=True)
|
||||
tools = [
|
||||
@@ -138,7 +138,7 @@ def test_agent_with_callbacks_local() -> None:
|
||||
tool = "Search"
|
||||
responses = [
|
||||
f"FooBarBaz\nAction: {tool}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses, callback_manager=manager, verbose=True)
|
||||
tools = [
|
||||
@@ -186,7 +186,7 @@ def test_agent_with_callbacks_not_verbose() -> None:
|
||||
tool = "Search"
|
||||
responses = [
|
||||
f"FooBarBaz\nAction: {tool}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses, callback_manager=manager)
|
||||
tools = [
|
||||
@@ -217,7 +217,7 @@ def test_agent_tool_return_direct() -> None:
|
||||
tool = "Search"
|
||||
responses = [
|
||||
f"FooBarBaz\nAction: {tool}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses)
|
||||
tools = [
|
||||
@@ -243,7 +243,7 @@ def test_agent_tool_return_direct_in_intermediate_steps() -> None:
|
||||
tool = "Search"
|
||||
responses = [
|
||||
f"FooBarBaz\nAction: {tool}\nAction Input: misalignment",
|
||||
"Oh well\nAction: Final Answer\nAction Input: curses foiled again",
|
||||
"Oh well\nFinal Answer: curses foiled again",
|
||||
]
|
||||
fake_llm = FakeListLLM(responses=responses)
|
||||
tools = [
|
||||
|
@@ -1,14 +1,26 @@
|
||||
"""Test MRKL functionality."""
|
||||
|
||||
from typing import Tuple
|
||||
|
||||
import pytest
|
||||
|
||||
from langchain.agents.mrkl.base import ZeroShotAgent, get_action_and_input
|
||||
from langchain.agents.mrkl.base import ZeroShotAgent
|
||||
from langchain.agents.mrkl.output_parser import MRKLOutputParser
|
||||
from langchain.agents.mrkl.prompt import FORMAT_INSTRUCTIONS, PREFIX, SUFFIX
|
||||
from langchain.agents.tools import Tool
|
||||
from langchain.prompts import PromptTemplate
|
||||
from langchain.schema import AgentAction
|
||||
from tests.unit_tests.llms.fake_llm import FakeLLM
|
||||
|
||||
|
||||
def get_action_and_input(text: str) -> Tuple[str, str]:
|
||||
output = MRKLOutputParser().parse(text)
|
||||
if isinstance(output, AgentAction):
|
||||
return output.tool, output.tool_input
|
||||
else:
|
||||
return "Final Answer", output.return_values["output"]
|
||||
|
||||
|
||||
def test_get_action_and_input() -> None:
|
||||
"""Test getting an action from text."""
|
||||
llm_output = (
|
||||
|
@@ -65,20 +65,6 @@ def test_predict_until_observation_normal() -> None:
|
||||
assert output == expected_output
|
||||
|
||||
|
||||
def test_predict_until_observation_repeat() -> None:
|
||||
"""Test when no action is generated initially."""
|
||||
outputs = ["foo", " Search[foo]"]
|
||||
fake_llm = FakeListLLM(responses=outputs)
|
||||
tools = [
|
||||
Tool(name="Search", func=lambda x: x, description="foo"),
|
||||
Tool(name="Lookup", func=lambda x: x, description="bar"),
|
||||
]
|
||||
agent = ReActDocstoreAgent.from_llm_and_tools(fake_llm, tools)
|
||||
output = agent.plan([], input="")
|
||||
expected_output = AgentAction("Search", "foo", "foo\nAction: Search[foo]")
|
||||
assert output == expected_output
|
||||
|
||||
|
||||
def test_react_chain() -> None:
|
||||
"""Test react chain."""
|
||||
responses = [
|
||||
|
Reference in New Issue
Block a user