From d4407e308e67605a17115ee2bdd496a9d33695ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erik=20Bj=C3=A4reholt?= Date: Sun, 5 Jan 2025 11:44:32 +0100 Subject: [PATCH] fix: rename python tool to ipython for better tooluse format adherence (#361) * fix: rename python tool to ipython for better tooluse format adherence * test: fixed subagent test using wrong toolname for ipython after rename --- gptme/tools/__init__.py | 2 +- gptme/tools/python.py | 3 ++- tests/test_cli.py | 2 +- tests/test_util_cli.py | 4 ++-- 4 files changed, 6 insertions(+), 5 deletions(-) diff --git a/gptme/tools/__init__.py b/gptme/tools/__init__.py index ea99e3a69..36a5a5921 100644 --- a/gptme/tools/__init__.py +++ b/gptme/tools/__init__.py @@ -77,7 +77,7 @@ def init_tools(allowlist: frozenset[str] | None = None) -> None: """Runs initialization logic for tools.""" # init python tool last tools = list( - sorted(ToolSpec.get_tools().values(), key=lambda tool: tool.name != "python") + sorted(ToolSpec.get_tools().values(), key=lambda tool: tool.name != "ipython") ) loaded_tool_names = [tool.name for tool in loaded_tools] for tool in tools: diff --git a/gptme/tools/python.py b/gptme/tools/python.py index 479e5f01f..d3be9cf9a 100644 --- a/gptme/tools/python.py +++ b/gptme/tools/python.py @@ -28,6 +28,7 @@ if TYPE_CHECKING: from IPython.core.interactiveshell import InteractiveShell # fmt: skip + logger = getLogger(__name__) # TODO: launch the IPython session in the current venv, if any, instead of the pipx-managed gptme venv (for example) in which gptme itself runs @@ -245,7 +246,7 @@ def init() -> ToolSpec: tool = ToolSpec( - name="python", + name="ipython", desc="Execute Python code", instructions=instructions, examples=examples, diff --git a/tests/test_cli.py b/tests/test_cli.py index 5f5692617..782e8603f 100644 --- a/tests/test_cli.py +++ b/tests/test_cli.py @@ -326,7 +326,7 @@ def test_subagent(args: list[str], runner: CliRunner): # f14: 377 # f15: 610 # f16: 987 - args.extend(["--tools", "python,subagent"]) + args.extend(["--tools", "ipython,subagent"]) args.extend( [ "We are in a test. Use the subagent tool to compute `fib(15)`, where `fib(1) = 1` and `fib(2) = 1`.", diff --git a/tests/test_util_cli.py b/tests/test_util_cli.py index 897e6642b..2dfac9460 100644 --- a/tests/test_util_cli.py +++ b/tests/test_util_cli.py @@ -137,9 +137,9 @@ def test_tools_info(): runner = CliRunner() # Test valid tool - result = runner.invoke(main, ["tools", "info", "python"]) + result = runner.invoke(main, ["tools", "info", "ipython"]) assert result.exit_code == 0 - assert "Tool: python" in result.output + assert "Tool: ipython" in result.output assert "Description:" in result.output assert "Instructions:" in result.output