forked from Archives/langchain
acfda4d1d8
Co-authored-by: Marc Päpper <mpaepper@users.noreply.github.com>
73 lines
1.9 KiB
Python
73 lines
1.9 KiB
Python
"""Test functionality of Python REPL."""
|
|
|
|
from langchain.python import PythonREPL
|
|
from langchain.tools.python.tool import PythonREPLTool
|
|
|
|
_SAMPLE_CODE = """
|
|
```
|
|
def multiply():
|
|
print(5*6)
|
|
multiply()
|
|
```
|
|
"""
|
|
|
|
|
|
def test_python_repl() -> None:
|
|
"""Test functionality when globals/locals are not provided."""
|
|
repl = PythonREPL()
|
|
|
|
# Run a simple initial command.
|
|
repl.run("foo = 1")
|
|
assert repl.locals is not None
|
|
assert repl.locals["foo"] == 1
|
|
|
|
# Now run a command that accesses `foo` to make sure it still has it.
|
|
repl.run("bar = foo * 2")
|
|
assert repl.locals is not None
|
|
assert repl.locals["bar"] == 2
|
|
|
|
|
|
def test_python_repl_no_previous_variables() -> None:
|
|
"""Test that it does not have access to variables created outside the scope."""
|
|
foo = 3 # noqa: F841
|
|
repl = PythonREPL()
|
|
output = repl.run("print(foo)")
|
|
assert output == "name 'foo' is not defined"
|
|
|
|
|
|
def test_python_repl_pass_in_locals() -> None:
|
|
"""Test functionality when passing in locals."""
|
|
_locals = {"foo": 4}
|
|
repl = PythonREPL(_locals=_locals)
|
|
repl.run("bar = foo * 2")
|
|
assert repl.locals is not None
|
|
assert repl.locals["bar"] == 8
|
|
|
|
|
|
def test_functionality() -> None:
|
|
"""Test correct functionality."""
|
|
chain = PythonREPL()
|
|
code = "print(1 + 1)"
|
|
output = chain.run(code)
|
|
assert output == "2\n"
|
|
|
|
|
|
def test_functionality_multiline() -> None:
|
|
"""Test correct functionality for ChatGPT multiline commands."""
|
|
chain = PythonREPL()
|
|
tool = PythonREPLTool(python_repl=chain)
|
|
output = tool.run(_SAMPLE_CODE)
|
|
assert output == "30\n"
|
|
|
|
|
|
def test_function() -> None:
|
|
"""Test correct functionality."""
|
|
chain = PythonREPL()
|
|
code = "def add(a, b): " " return a + b"
|
|
output = chain.run(code)
|
|
assert output == ""
|
|
|
|
code = "print(add(1, 2))"
|
|
output = chain.run(code)
|
|
assert output == "3\n"
|