From 758edb7c02a31481de88390332575e863407183b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomek=20S=C5=82oma?= <82450784+Hedrekao@users.noreply.github.com> Date: Mon, 25 Nov 2024 19:20:46 +0100 Subject: [PATCH] Bugfix: Web surfer creating incomplete copy of messages (#4050) * bugfix: create full copy of history (including last message) * websurfer: copy entire message context only when last message is tool message --- autogen/agentchat/contrib/web_surfer.py | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/autogen/agentchat/contrib/web_surfer.py b/autogen/agentchat/contrib/web_surfer.py index 1a2dd2e3236b..7ceed7d79174 100644 --- a/autogen/agentchat/contrib/web_surfer.py +++ b/autogen/agentchat/contrib/web_surfer.py @@ -230,7 +230,7 @@ def _page_down() -> str: def _find_on_page_ctrl_f( search_string: Annotated[ str, "The string to search for on the page. This search string supports wildcards like '*'" - ] + ], ) -> str: find_result = self.browser.find_on_page(search_string) header, content = _browser_state() @@ -344,7 +344,17 @@ def generate_surfer_reply( # Clone the messages to give context self._assistant.chat_messages[self._user_proxy] = list() - history = messages[0 : len(messages) - 1] + + # If the last message is a tool message it has to be included in context, + # otherwise openAI will throw exception that not all tool calls are followed by corresponding tool messages + # In a case where the last message is not a tool message, we fallback to default behavior in the library + # which is copying all messages except the last one + # Issue is described more thoroughly in PR https://github.com/microsoft/autogen/pull/4050 + if messages[-1].get("role", "assistant") == "tool": + history = messages[:] + else: + history = messages[0 : len(messages) - 1] + for message in history: self._assistant.chat_messages[self._user_proxy].append(message)