import { mock } from 'jest-mock-extended'; import { DynamicTool } from 'langchain/tools'; import type { ISupplyDataFunctions, INode } from 'n8n-workflow'; import { ToolThink } from '../ToolThink.node'; describe('ToolThink', () => { const thinkTool = new ToolThink(); const helpers = mock(); const createExecuteFunctions = (node: Partial = { typeVersion: 1 }) => { const executeFunctions = mock({ helpers, }); executeFunctions.addInputData.mockReturnValue({ index: 0 }); executeFunctions.getNodeParameter.mockImplementation((paramName: string) => { switch (paramName) { case 'description': return 'Tool description'; default: return undefined; } }); executeFunctions.getNode.mockReturnValue(mock(node)); return executeFunctions; }; describe('Tool response', () => { it('should return the same text as response when receiving a text input', async () => { const executeFunctions = createExecuteFunctions(); const { response } = (await thinkTool.supplyData.call(executeFunctions, 0)) as { response: DynamicTool; }; expect(response).toBeInstanceOf(DynamicTool); expect(response.description).toEqual('Tool description'); const res = (await response.invoke('foo')) as string; expect(res).toEqual('foo'); }); it('should use hardcoded name for version 1', async () => { const executeFunctions = createExecuteFunctions({ typeVersion: 1 }); const { response } = (await thinkTool.supplyData.call(executeFunctions, 0)) as { response: DynamicTool; }; expect(response.name).toEqual('thinking_tool'); }); it('should use dynamic name from node for version 1.1', async () => { const executeFunctions = createExecuteFunctions({ typeVersion: 1.1, name: 'My Thinking Tool', }); const { response } = (await thinkTool.supplyData.call(executeFunctions, 0)) as { response: DynamicTool; }; expect(response.name).toEqual('My_Thinking_Tool'); }); }); });