From 9d8845fbac6a54846034e289fe5f69a5d4bfe8ea Mon Sep 17 00:00:00 2001 From: Arvin Xu Date: Mon, 25 Nov 2024 21:17:24 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20fix:=20fix=20multi-turns=20tools?= =?UTF-8?q?=20calling=20(#4789)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * 🐛 fix: fix tools calling * 🐛 fix: fix tools calling --- .../chat/slices/aiChat/actions/generateAIChat.ts | 4 ++-- src/store/chat/slices/message/selectors.test.ts | 13 +++++++++++++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/store/chat/slices/aiChat/actions/generateAIChat.ts b/src/store/chat/slices/aiChat/actions/generateAIChat.ts index 86dd6d871d9b..a7b41ecb44d5 100644 --- a/src/store/chat/slices/aiChat/actions/generateAIChat.ts +++ b/src/store/chat/slices/aiChat/actions/generateAIChat.ts @@ -207,7 +207,7 @@ export const generateAIChat: StateCreator< } // Get the current messages to generate AI response - const messages = chatSelectors.mainDisplayChats(get()); + const messages = chatSelectors.activeBaseChats(get()); const userFiles = chatSelectors.currentUserFiles(get()).map((f) => f.id); await internal_coreProcessMessage(messages, id, { @@ -484,7 +484,7 @@ export const generateAIChat: StateCreator< internal_resendMessage: async (messageId, traceId) => { // 1. 构造所有相关的历史记录 - const chats = chatSelectors.mainDisplayChats(get()); + const chats = chatSelectors.activeBaseChats(get()); const currentIndex = chats.findIndex((c) => c.id === messageId); if (currentIndex < 0) return; diff --git a/src/store/chat/slices/message/selectors.test.ts b/src/store/chat/slices/message/selectors.test.ts index c9e9994683c0..e91692ea53f5 100644 --- a/src/store/chat/slices/message/selectors.test.ts +++ b/src/store/chat/slices/message/selectors.test.ts @@ -232,6 +232,19 @@ describe('chatSelectors', () => { }); }); + describe('mainDisplayChats', () => { + it('should return existing messages except tool message', () => { + const state = merge(initialStore, { + messagesMap: { + [messageMapKey('someActiveId')]: mockMessages, + }, + activeId: 'someActiveId', + }); + const chats = chatSelectors.mainDisplayChats(state); + expect(chats).toEqual(mockedChats.slice(0, 2)); + }); + }); + describe('chatsMessageString', () => { it('should concatenate the contents of all messages returned by currentChatsWithHistoryConfig', () => { // Prepare a state with a few messages