"""Issue #2925 — a fenced ```python/```bash block wrapping an call that can't be converted (e.g. a hyphenated/namespaced tool name that _XML_INVOKE_RE's \\w+ won't match, or an unknown tool) must NOT fall through and ship the raw XML to the code executor as if it were python/bash. """ import sys from unittest.mock import MagicMock for mod in ['src.agent_tools', 'src.tool_parsing', 'src.tool_schemas', 'src.tool_execution']: sys.modules.pop(mod, None) for mod in [ 'sqlalchemy', 'sqlalchemy.orm', 'sqlalchemy.ext', 'sqlalchemy.ext.declarative', 'sqlalchemy.ext.hybrid', 'sqlalchemy.sql', 'sqlalchemy.sql.expression', 'src.database', 'core.models', 'core.database', 'core.auth' ]: if mod not in sys.modules: sys.modules[mod] = MagicMock() import src.agent_tools # noqa: E402, F401 from src.tool_parsing import parse_tool_blocks # noqa: E402 def test_unconvertible_invoke_in_fence_is_not_executed_as_code(): text = '```python\n\n1\n\n```' blocks = parse_tool_blocks(text) # the hyphenated name can't match _XML_INVOKE_RE, so nothing converts — # the raw XML must not be appended as a python/bash code block. assert not any( b.tool_type in ("python", "bash") and ") still works. blocks = parse_tool_blocks('```python\nprint("hi")\n```') assert any(b.tool_type == "python" and 'print("hi")' in b.content for b in blocks), blocks def test_simple_web_search_call_inside_python_fence_runs_as_web_search(): blocks = parse_tool_blocks('```python\nweb_search("latest Python release")\n```') assert len(blocks) == 1 assert blocks[0].tool_type == "web_search" assert blocks[0].content == "latest Python release" def test_google_search_alias_inside_bash_fence_preserves_freshness_args(): blocks = parse_tool_blocks( '```bash\ngoogle_search(query="Qwen latest release", freshness="week", max_pages=7)\n```' ) assert len(blocks) == 1 assert blocks[0].tool_type == "web_search" assert '"query": "Qwen latest release"' in blocks[0].content assert '"freshness": "week"' in blocks[0].content assert '"max_pages": 7' in blocks[0].content def test_nontrivial_python_with_web_search_name_stays_python_code(): blocks = parse_tool_blocks('```python\nprint(web_search("latest Python release"))\n```') assert len(blocks) == 1 assert blocks[0].tool_type == "python" def test_plain_search_function_inside_python_fence_stays_python_code(): blocks = parse_tool_blocks('```python\nsearch("private customer name")\n```') assert len(blocks) == 1 assert blocks[0].tool_type == "python" def test_plain_fetch_function_inside_python_fence_stays_python_code(): blocks = parse_tool_blocks('```python\nfetch("internal-url")\n```') assert len(blocks) == 1 assert blocks[0].tool_type == "python"