From e2bedb041572e791222e960f17e5e9c6eb2edb7f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vojt=C4=9Bch=20Tranta?= Date: Wed, 4 Sep 2024 16:19:39 +0200 Subject: [PATCH] fix passing of the assistant options to the invoke --- src/LangtailAssistants.spec.ts | 47 +++++++++++++++++++++++++++++----- src/LangtailAssistants.ts | 5 ++-- src/schemas.ts | 2 ++ 3 files changed, 45 insertions(+), 9 deletions(-) diff --git a/src/LangtailAssistants.spec.ts b/src/LangtailAssistants.spec.ts index c67d346..1dab789 100644 --- a/src/LangtailAssistants.spec.ts +++ b/src/LangtailAssistants.spec.ts @@ -26,15 +26,15 @@ class MockLangtailPrompts implements ILangtailPrompts { } describe("LangtailAssistants", () => { - describe("public API", () => { - const createLt = () => { - const promptsMock = new MockLangtailPrompts() - return { - lt: new LangtailAssistants(promptsMock), - promptsMock - } + const createLt = () => { + const promptsMock = new MockLangtailPrompts() + return { + lt: new LangtailAssistants(promptsMock), + promptsMock } + } + describe("public API", () => { it("should translate assistant to prompt option in langtailPrompts.invoke call", async () => { const { lt, promptsMock } = createLt(); const assistant = "test-assistant"; @@ -43,6 +43,7 @@ describe("LangtailAssistants", () => { expect(promptsMock.invoke).toHaveBeenCalledWith( expect.objectContaining({ + assistant: true, prompt: assistant, }) ); @@ -90,6 +91,7 @@ describe("LangtailAssistants", () => { }); expect(promptsMock.invoke).toHaveBeenCalledWith({ + assistant: true, prompt: assistant, messages, }); @@ -106,4 +108,35 @@ describe("LangtailAssistants", () => { expect(result).toBe(mockResponse); }); }) + + it("should pass assistant: true by default to langtailPrompts.invoke call", async () => { + const { lt, promptsMock } = createLt(); + const assistant = "test-assistant"; + + await lt.invoke({ assistant }); + + expect(promptsMock.invoke).toHaveBeenCalledWith( + expect.objectContaining({ + assistant: true, + prompt: "test-assistant", + }) + ); + }); + + it("should pass threadId to langtailPrompts.invoke call when provided", async () => { + const { lt, promptsMock } = createLt(); + const assistant = "test-assistant"; + const threadId = "test-thread-id"; + + await lt.invoke({ assistant, threadId }); + + expect(promptsMock.invoke).toHaveBeenCalledWith( + expect.objectContaining({ + assistant: true, + prompt: assistant, + threadId: threadId, + }) + ); + }); + }) \ No newline at end of file diff --git a/src/LangtailAssistants.ts b/src/LangtailAssistants.ts index 41001f7..151b85f 100644 --- a/src/LangtailAssistants.ts +++ b/src/LangtailAssistants.ts @@ -12,13 +12,14 @@ export class LangtailAssistants { this.langtailPrompts = langtailPrompts } - invoke

= undefined, V extends Version = undefined, S extends boolean = false>(options: Omit, "prompt"> & { + invoke

= undefined, V extends Version = undefined, S extends boolean = false>(options: Omit, "prompt" | "assistant"> & { assistant: P }): Promise { const { assistant, ...rest } = options return this.langtailPrompts.invoke({ ...rest, - prompt: assistant + prompt: assistant, + assistant: true, }) } } \ No newline at end of file diff --git a/src/schemas.ts b/src/schemas.ts index f3be1da..47ec89f 100644 --- a/src/schemas.ts +++ b/src/schemas.ts @@ -7,6 +7,8 @@ import type { export interface ILangtailExtraProps { doNotRecord?: boolean + threadId?: string + assistant?: boolean metadata?: Record }