mirror of
https://github.com/QwenLM/qwen-code.git
synced 2025-12-21 09:17:53 +00:00
Change the type of ToolResult.responseParts (#6875)
This commit is contained in:
committed by
GitHub
parent
9a0722625b
commit
75822d3506
@@ -15,7 +15,7 @@ import {
|
||||
MockInstance,
|
||||
} from 'vitest';
|
||||
import { renderHook, act, waitFor } from '@testing-library/react';
|
||||
import { useGeminiStream, mergePartListUnions } from './useGeminiStream.js';
|
||||
import { useGeminiStream } from './useGeminiStream.js';
|
||||
import { useKeypress } from './useKeypress.js';
|
||||
import * as atCommandProcessor from './atCommandProcessor.js';
|
||||
import {
|
||||
@@ -138,125 +138,6 @@ vi.mock('./slashCommandProcessor.js', () => ({
|
||||
|
||||
// --- END MOCKS ---
|
||||
|
||||
describe('mergePartListUnions', () => {
|
||||
it('should merge multiple PartListUnion arrays', () => {
|
||||
const list1: PartListUnion = [{ text: 'Hello' }];
|
||||
const list2: PartListUnion = [
|
||||
{ inlineData: { mimeType: 'image/png', data: 'abc' } },
|
||||
];
|
||||
const list3: PartListUnion = [{ text: 'World' }, { text: '!' }];
|
||||
const result = mergePartListUnions([list1, list2, list3]);
|
||||
expect(result).toEqual([
|
||||
{ text: 'Hello' },
|
||||
{ inlineData: { mimeType: 'image/png', data: 'abc' } },
|
||||
{ text: 'World' },
|
||||
{ text: '!' },
|
||||
]);
|
||||
});
|
||||
|
||||
it('should handle empty arrays in the input list', () => {
|
||||
const list1: PartListUnion = [{ text: 'First' }];
|
||||
const list2: PartListUnion = [];
|
||||
const list3: PartListUnion = [{ text: 'Last' }];
|
||||
const result = mergePartListUnions([list1, list2, list3]);
|
||||
expect(result).toEqual([{ text: 'First' }, { text: 'Last' }]);
|
||||
});
|
||||
|
||||
it('should handle a single PartListUnion array', () => {
|
||||
const list1: PartListUnion = [
|
||||
{ text: 'One' },
|
||||
{ inlineData: { mimeType: 'image/jpeg', data: 'xyz' } },
|
||||
];
|
||||
const result = mergePartListUnions([list1]);
|
||||
expect(result).toEqual(list1);
|
||||
});
|
||||
|
||||
it('should return an empty array if all input arrays are empty', () => {
|
||||
const list1: PartListUnion = [];
|
||||
const list2: PartListUnion = [];
|
||||
const result = mergePartListUnions([list1, list2]);
|
||||
expect(result).toEqual([]);
|
||||
});
|
||||
|
||||
it('should handle input list being empty', () => {
|
||||
const result = mergePartListUnions([]);
|
||||
expect(result).toEqual([]);
|
||||
});
|
||||
|
||||
it('should correctly merge when PartListUnion items are single Parts not in arrays', () => {
|
||||
const part1: Part = { text: 'Single part 1' };
|
||||
const part2: Part = { inlineData: { mimeType: 'image/gif', data: 'gif' } };
|
||||
const listContainingSingleParts: PartListUnion[] = [
|
||||
part1,
|
||||
[part2],
|
||||
{ text: 'Another single part' },
|
||||
];
|
||||
const result = mergePartListUnions(listContainingSingleParts);
|
||||
expect(result).toEqual([
|
||||
{ text: 'Single part 1' },
|
||||
{ inlineData: { mimeType: 'image/gif', data: 'gif' } },
|
||||
{ text: 'Another single part' },
|
||||
]);
|
||||
});
|
||||
|
||||
it('should handle a mix of arrays and single parts, including empty arrays and undefined/null parts if they were possible (though PartListUnion typing restricts this)', () => {
|
||||
const list1: PartListUnion = [{ text: 'A' }];
|
||||
const list2: PartListUnion = [];
|
||||
const part3: Part = { text: 'B' };
|
||||
const list4: PartListUnion = [
|
||||
{ text: 'C' },
|
||||
{ inlineData: { mimeType: 'text/plain', data: 'D' } },
|
||||
];
|
||||
const result = mergePartListUnions([list1, list2, part3, list4]);
|
||||
expect(result).toEqual([
|
||||
{ text: 'A' },
|
||||
{ text: 'B' },
|
||||
{ text: 'C' },
|
||||
{ inlineData: { mimeType: 'text/plain', data: 'D' } },
|
||||
]);
|
||||
});
|
||||
|
||||
it('should preserve the order of parts from the input arrays', () => {
|
||||
const listA: PartListUnion = [{ text: '1' }, { text: '2' }];
|
||||
const listB: PartListUnion = [{ text: '3' }];
|
||||
const listC: PartListUnion = [{ text: '4' }, { text: '5' }];
|
||||
const result = mergePartListUnions([listA, listB, listC]);
|
||||
expect(result).toEqual([
|
||||
{ text: '1' },
|
||||
{ text: '2' },
|
||||
{ text: '3' },
|
||||
{ text: '4' },
|
||||
{ text: '5' },
|
||||
]);
|
||||
});
|
||||
|
||||
it('should handle cases where some PartListUnion items are single Parts and others are arrays of Parts', () => {
|
||||
const singlePart1: Part = { text: 'First single' };
|
||||
const arrayPart1: Part[] = [
|
||||
{ text: 'Array item 1' },
|
||||
{ text: 'Array item 2' },
|
||||
];
|
||||
const singlePart2: Part = {
|
||||
inlineData: { mimeType: 'application/json', data: 'e30=' },
|
||||
}; // {}
|
||||
const arrayPart2: Part[] = [{ text: 'Last array item' }];
|
||||
|
||||
const result = mergePartListUnions([
|
||||
singlePart1,
|
||||
arrayPart1,
|
||||
singlePart2,
|
||||
arrayPart2,
|
||||
]);
|
||||
expect(result).toEqual([
|
||||
{ text: 'First single' },
|
||||
{ text: 'Array item 1' },
|
||||
{ text: 'Array item 2' },
|
||||
{ inlineData: { mimeType: 'application/json', data: 'e30=' } },
|
||||
{ text: 'Last array item' },
|
||||
]);
|
||||
});
|
||||
});
|
||||
|
||||
// --- Tests for useGeminiStream Hook ---
|
||||
describe('useGeminiStream', () => {
|
||||
let mockAddItem: Mock;
|
||||
@@ -505,12 +386,8 @@ describe('useGeminiStream', () => {
|
||||
});
|
||||
|
||||
it('should submit tool responses when all tool calls are completed and ready', async () => {
|
||||
const toolCall1ResponseParts: PartListUnion = [
|
||||
{ text: 'tool 1 final response' },
|
||||
];
|
||||
const toolCall2ResponseParts: PartListUnion = [
|
||||
{ text: 'tool 2 final response' },
|
||||
];
|
||||
const toolCall1ResponseParts: Part[] = [{ text: 'tool 1 final response' }];
|
||||
const toolCall2ResponseParts: Part[] = [{ text: 'tool 2 final response' }];
|
||||
const completedToolCalls: TrackedToolCall[] = [
|
||||
{
|
||||
request: {
|
||||
@@ -593,10 +470,10 @@ describe('useGeminiStream', () => {
|
||||
expect(mockSendMessageStream).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
const expectedMergedResponse = mergePartListUnions([
|
||||
toolCall1ResponseParts,
|
||||
toolCall2ResponseParts,
|
||||
]);
|
||||
const expectedMergedResponse = [
|
||||
...toolCall1ResponseParts,
|
||||
...toolCall2ResponseParts,
|
||||
];
|
||||
expect(mockSendMessageStream).toHaveBeenCalledWith(
|
||||
expectedMergedResponse,
|
||||
expect.any(AbortSignal),
|
||||
|
||||
Reference in New Issue
Block a user