From d9df403a64878d2d4966fd714871597b199c515b Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 12:58:50 -0700 Subject: [PATCH 01/24] cohere[minor]: Fix token counts, add usage_metadata --- libs/langchain-cohere/package.json | 2 +- libs/langchain-cohere/src/chat_models.ts | 76 +- .../src/tests/chat_models.int.test.ts | 47 +- yarn.lock | 816 +++++++++++++++++- 4 files changed, 919 insertions(+), 22 deletions(-) diff --git a/libs/langchain-cohere/package.json b/libs/langchain-cohere/package.json index a06f9dccaba1..9f7ab1ce4641 100644 --- a/libs/langchain-cohere/package.json +++ b/libs/langchain-cohere/package.json @@ -36,7 +36,7 @@ "license": "MIT", "dependencies": { "@langchain/core": ">0.1.58 <0.3.0", - "cohere-ai": "^7.9.3" + "cohere-ai": "^7.10.5" }, "devDependencies": { "@jest/globals": "^29.5.0", diff --git a/libs/langchain-cohere/src/chat_models.ts b/libs/langchain-cohere/src/chat_models.ts index 2179ec0bbc5d..0b0620217070 100644 --- a/libs/langchain-cohere/src/chat_models.ts +++ b/libs/langchain-cohere/src/chat_models.ts @@ -62,7 +62,7 @@ export interface CohereChatCallOptions function convertMessagesToCohereMessages( messages: Array -): Array { +): Array { const getRole = (role: MessageType) => { switch (role) { case "system": @@ -113,7 +113,7 @@ function convertMessagesToCohereMessages( export class ChatCohere< CallOptions extends CohereChatCallOptions = CohereChatCallOptions > - extends BaseChatModel + extends BaseChatModel implements ChatCohereInput { static lc_name() { @@ -193,8 +193,14 @@ export class ChatCohere< const cohereMessages = convertMessagesToCohereMessages(messages); // The last message in the array is the most recent, all other messages // are apart of the chat history. - const { message } = cohereMessages[cohereMessages.length - 1]; - const chatHistory: Cohere.ChatMessage[] = []; + const lastMessage = cohereMessages[cohereMessages.length - 1]; + if (lastMessage.role === "TOOL") { + throw new Error( + "Cohere does not support tool messages as the most recent message in chat history." + ); + } + const { message } = lastMessage; + const chatHistory: Cohere.Message[] = []; if (cohereMessages.length > 1) { chatHistory.push(...cohereMessages.slice(0, -1)); } @@ -241,25 +247,22 @@ export class ChatCohere< } ); - if ("token_count" in response) { + if (response.meta?.tokens) { const { - response_tokens: completionTokens, - prompt_tokens: promptTokens, - total_tokens: totalTokens, - } = response.token_count as Record; + inputTokens, + outputTokens, + } = response.meta.tokens; - if (completionTokens) { + if (outputTokens) { tokenUsage.completionTokens = - (tokenUsage.completionTokens ?? 0) + completionTokens; + (tokenUsage.completionTokens ?? 0) + outputTokens; } - if (promptTokens) { - tokenUsage.promptTokens = (tokenUsage.promptTokens ?? 0) + promptTokens; + if (inputTokens) { + tokenUsage.promptTokens = (tokenUsage.promptTokens ?? 0) + inputTokens; } - if (totalTokens) { - tokenUsage.totalTokens = (tokenUsage.totalTokens ?? 0) + totalTokens; - } + tokenUsage.totalTokens = (tokenUsage.totalTokens ?? 0) + (tokenUsage.promptTokens ?? 0) + (tokenUsage.completionTokens ?? 0); } const generationInfo: Record = { ...response }; @@ -271,6 +274,11 @@ export class ChatCohere< message: new AIMessage({ content: response.text, additional_kwargs: generationInfo, + usage_metadata: { + input_tokens: tokenUsage.promptTokens ?? 0, + output_tokens: tokenUsage.completionTokens ?? 0, + total_tokens: tokenUsage.totalTokens ?? 0, + } }), generationInfo, }, @@ -290,8 +298,14 @@ export class ChatCohere< const cohereMessages = convertMessagesToCohereMessages(messages); // The last message in the array is the most recent, all other messages // are apart of the chat history. - const { message } = cohereMessages[cohereMessages.length - 1]; - const chatHistory: Cohere.ChatMessage[] = []; + const lastMessage = cohereMessages[cohereMessages.length - 1]; + if (lastMessage.role === "TOOL") { + throw new Error( + "Cohere does not support tool messages as the most recent message in chat history." + ); + } + const { message } = lastMessage; + const chatHistory: Cohere.Message[] = []; if (cohereMessages.length > 1) { chatHistory.push(...cohereMessages.slice(0, -1)); } @@ -335,6 +349,32 @@ export class ChatCohere< ...chunk, }, }); + } else if ( + chunk.eventType === "stream-end" && + chunk.response.meta?.tokens && + (chunk.response.meta.tokens.inputTokens || + chunk.response.meta.tokens.outputTokens) + ) { + // stream-end events contain the final token count + const input_tokens = chunk.response.meta.tokens.inputTokens ?? 0; + const output_tokens = chunk.response.meta.tokens.outputTokens ?? 0; + yield new ChatGenerationChunk({ + text: "", + message: new AIMessageChunk({ + content: "", + additional_kwargs: { + eventType: "stream-end", + }, + usage_metadata: { + input_tokens, + output_tokens, + total_tokens: input_tokens + output_tokens, + }, + }), + generationInfo: { + eventType: "stream-end", + }, + }); } } } diff --git a/libs/langchain-cohere/src/tests/chat_models.int.test.ts b/libs/langchain-cohere/src/tests/chat_models.int.test.ts index 03fc8ddf66f8..e3c9332e3cbf 100644 --- a/libs/langchain-cohere/src/tests/chat_models.int.test.ts +++ b/libs/langchain-cohere/src/tests/chat_models.int.test.ts @@ -1,6 +1,6 @@ /* eslint-disable no-promise-executor-return */ import { test, expect } from "@jest/globals"; -import { HumanMessage } from "@langchain/core/messages"; +import { AIMessageChunk, HumanMessage } from "@langchain/core/messages"; import { ChatCohere } from "../chat_models.js"; test("ChatCohere can invoke", async () => { @@ -58,3 +58,48 @@ test("should abort the request", async () => { return ret; }).rejects.toThrow("AbortError"); }); + +test("Stream token count usage_metadata", async () => { + const model = new ChatCohere({ + model: "command-light", + temperature: 0, + }); + let res: AIMessageChunk | null = null; + for await (const chunk of await model.stream( + "Why is the sky blue? Be concise." + )) { + if (!res) { + res = chunk; + } else { + res = res.concat(chunk); + } + } + console.log(res); + expect(res?.usage_metadata).toBeDefined(); + if (!res?.usage_metadata) { + return; + } + expect(res.usage_metadata.input_tokens).toBe(71); + expect(res.usage_metadata.output_tokens).toBeGreaterThan(10); + expect(res.usage_metadata.total_tokens).toBe( + res.usage_metadata.input_tokens + res.usage_metadata.output_tokens + ); +}); + +test.only("Invoke token count usage_metadata", async () => { + const model = new ChatCohere({ + model: "command-light", + temperature: 0, + }); + const res = await model.invoke("Why is the sky blue? Be concise."); + console.log(res); + expect(res?.usage_metadata).toBeDefined(); + if (!res?.usage_metadata) { + return; + } + expect(res.usage_metadata.input_tokens).toBe(71); + expect(res.usage_metadata.output_tokens).toBeGreaterThan(10); + expect(res.usage_metadata.total_tokens).toBe( + res.usage_metadata.input_tokens + res.usage_metadata.output_tokens + ); +}); diff --git a/yarn.lock b/yarn.lock index cd629e4535e1..2e1d0b8c9f20 100644 --- a/yarn.lock +++ b/yarn.lock @@ -510,6 +510,55 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/client-cognito-identity@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/client-cognito-identity@npm:3.592.0" + dependencies: + "@aws-crypto/sha256-browser": 3.0.0 + "@aws-crypto/sha256-js": 3.0.0 + "@aws-sdk/client-sso-oidc": 3.592.0 + "@aws-sdk/client-sts": 3.592.0 + "@aws-sdk/core": 3.592.0 + "@aws-sdk/credential-provider-node": 3.592.0 + "@aws-sdk/middleware-host-header": 3.577.0 + "@aws-sdk/middleware-logger": 3.577.0 + "@aws-sdk/middleware-recursion-detection": 3.577.0 + "@aws-sdk/middleware-user-agent": 3.587.0 + "@aws-sdk/region-config-resolver": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@aws-sdk/util-user-agent-browser": 3.577.0 + "@aws-sdk/util-user-agent-node": 3.587.0 + "@smithy/config-resolver": ^3.0.1 + "@smithy/core": ^2.2.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/hash-node": ^3.0.0 + "@smithy/invalid-dependency": ^3.0.0 + "@smithy/middleware-content-length": ^3.0.0 + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-base64": ^3.0.0 + "@smithy/util-body-length-browser": ^3.0.0 + "@smithy/util-body-length-node": ^3.0.0 + "@smithy/util-defaults-mode-browser": ^3.0.3 + "@smithy/util-defaults-mode-node": ^3.0.3 + "@smithy/util-endpoints": ^2.0.1 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + "@smithy/util-utf8": ^3.0.0 + tslib: ^2.6.2 + checksum: 2ce5e19512a7547c461a8ce55765a91da71fbd521a07716866b4d9140ed801f39126dd2aad167672ddf3fb69702a3fa3dfd279e026d611b0a1e4211c264c85a9 + languageName: node + linkType: hard + "@aws-sdk/client-dynamodb@npm:^3.310.0": version: 3.327.0 resolution: "@aws-sdk/client-dynamodb@npm:3.327.0" @@ -759,6 +808,57 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/client-sagemaker@npm:^3.583.0": + version: 3.595.0 + resolution: "@aws-sdk/client-sagemaker@npm:3.595.0" + dependencies: + "@aws-crypto/sha256-browser": 3.0.0 + "@aws-crypto/sha256-js": 3.0.0 + "@aws-sdk/client-sso-oidc": 3.592.0 + "@aws-sdk/client-sts": 3.592.0 + "@aws-sdk/core": 3.592.0 + "@aws-sdk/credential-provider-node": 3.592.0 + "@aws-sdk/middleware-host-header": 3.577.0 + "@aws-sdk/middleware-logger": 3.577.0 + "@aws-sdk/middleware-recursion-detection": 3.577.0 + "@aws-sdk/middleware-user-agent": 3.587.0 + "@aws-sdk/region-config-resolver": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@aws-sdk/util-user-agent-browser": 3.577.0 + "@aws-sdk/util-user-agent-node": 3.587.0 + "@smithy/config-resolver": ^3.0.1 + "@smithy/core": ^2.2.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/hash-node": ^3.0.0 + "@smithy/invalid-dependency": ^3.0.0 + "@smithy/middleware-content-length": ^3.0.0 + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-base64": ^3.0.0 + "@smithy/util-body-length-browser": ^3.0.0 + "@smithy/util-body-length-node": ^3.0.0 + "@smithy/util-defaults-mode-browser": ^3.0.3 + "@smithy/util-defaults-mode-node": ^3.0.3 + "@smithy/util-endpoints": ^2.0.1 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + "@smithy/util-utf8": ^3.0.0 + "@smithy/util-waiter": ^3.0.0 + tslib: ^2.6.2 + uuid: ^9.0.1 + checksum: d208805eecbb01dd3ee4a1fa121af0038fc370482dd3401a748ade3276a40676a1ab69713e8394484f6b7141c637fc8a44dca0abe0f74d2b5363edf86f2657f1 + languageName: node + linkType: hard + "@aws-sdk/client-sfn@npm:^3.362.0": version: 3.362.0 resolution: "@aws-sdk/client-sfn@npm:3.362.0" @@ -1013,6 +1113,54 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/client-sso-oidc@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/client-sso-oidc@npm:3.592.0" + dependencies: + "@aws-crypto/sha256-browser": 3.0.0 + "@aws-crypto/sha256-js": 3.0.0 + "@aws-sdk/client-sts": 3.592.0 + "@aws-sdk/core": 3.592.0 + "@aws-sdk/credential-provider-node": 3.592.0 + "@aws-sdk/middleware-host-header": 3.577.0 + "@aws-sdk/middleware-logger": 3.577.0 + "@aws-sdk/middleware-recursion-detection": 3.577.0 + "@aws-sdk/middleware-user-agent": 3.587.0 + "@aws-sdk/region-config-resolver": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@aws-sdk/util-user-agent-browser": 3.577.0 + "@aws-sdk/util-user-agent-node": 3.587.0 + "@smithy/config-resolver": ^3.0.1 + "@smithy/core": ^2.2.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/hash-node": ^3.0.0 + "@smithy/invalid-dependency": ^3.0.0 + "@smithy/middleware-content-length": ^3.0.0 + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-base64": ^3.0.0 + "@smithy/util-body-length-browser": ^3.0.0 + "@smithy/util-body-length-node": ^3.0.0 + "@smithy/util-defaults-mode-browser": ^3.0.3 + "@smithy/util-defaults-mode-node": ^3.0.3 + "@smithy/util-endpoints": ^2.0.1 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + "@smithy/util-utf8": ^3.0.0 + tslib: ^2.6.2 + checksum: 31baf5a17e1da21e6f95a2da05663dbfd9f5368dc91f7e0f80ce521cc1e3f32c98ba89b8394069bdb8cafa216929247172437494f38254cf1761c92de09fa7e6 + languageName: node + linkType: hard + "@aws-sdk/client-sso@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/client-sso@npm:3.310.0" @@ -1349,6 +1497,52 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/client-sso@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/client-sso@npm:3.592.0" + dependencies: + "@aws-crypto/sha256-browser": 3.0.0 + "@aws-crypto/sha256-js": 3.0.0 + "@aws-sdk/core": 3.592.0 + "@aws-sdk/middleware-host-header": 3.577.0 + "@aws-sdk/middleware-logger": 3.577.0 + "@aws-sdk/middleware-recursion-detection": 3.577.0 + "@aws-sdk/middleware-user-agent": 3.587.0 + "@aws-sdk/region-config-resolver": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@aws-sdk/util-user-agent-browser": 3.577.0 + "@aws-sdk/util-user-agent-node": 3.587.0 + "@smithy/config-resolver": ^3.0.1 + "@smithy/core": ^2.2.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/hash-node": ^3.0.0 + "@smithy/invalid-dependency": ^3.0.0 + "@smithy/middleware-content-length": ^3.0.0 + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-base64": ^3.0.0 + "@smithy/util-body-length-browser": ^3.0.0 + "@smithy/util-body-length-node": ^3.0.0 + "@smithy/util-defaults-mode-browser": ^3.0.3 + "@smithy/util-defaults-mode-node": ^3.0.3 + "@smithy/util-endpoints": ^2.0.1 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + "@smithy/util-utf8": ^3.0.0 + tslib: ^2.6.2 + checksum: e993043e8438e1cc0445b61de485951e957f0889135b3e34f79b7080852f369b13d516dc6c027f8d3c8ad95cc41666f63f0543e04c10ec9e120b3e025a34367e + languageName: node + linkType: hard + "@aws-sdk/client-sts@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/client-sts@npm:3.310.0" @@ -1669,6 +1863,54 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/client-sts@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/client-sts@npm:3.592.0" + dependencies: + "@aws-crypto/sha256-browser": 3.0.0 + "@aws-crypto/sha256-js": 3.0.0 + "@aws-sdk/client-sso-oidc": 3.592.0 + "@aws-sdk/core": 3.592.0 + "@aws-sdk/credential-provider-node": 3.592.0 + "@aws-sdk/middleware-host-header": 3.577.0 + "@aws-sdk/middleware-logger": 3.577.0 + "@aws-sdk/middleware-recursion-detection": 3.577.0 + "@aws-sdk/middleware-user-agent": 3.587.0 + "@aws-sdk/region-config-resolver": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@aws-sdk/util-user-agent-browser": 3.577.0 + "@aws-sdk/util-user-agent-node": 3.587.0 + "@smithy/config-resolver": ^3.0.1 + "@smithy/core": ^2.2.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/hash-node": ^3.0.0 + "@smithy/invalid-dependency": ^3.0.0 + "@smithy/middleware-content-length": ^3.0.0 + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-base64": ^3.0.0 + "@smithy/util-body-length-browser": ^3.0.0 + "@smithy/util-body-length-node": ^3.0.0 + "@smithy/util-defaults-mode-browser": ^3.0.3 + "@smithy/util-defaults-mode-node": ^3.0.3 + "@smithy/util-endpoints": ^2.0.1 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + "@smithy/util-utf8": ^3.0.0 + tslib: ^2.6.2 + checksum: 3675ca053f840a7c3bd8b2413655d69988dd9dff9e1056aa5f3825021c1c7484baddbf1ded1f2e60f1338cecd81d326e28afed39b32b22413b3651cc7157647d + languageName: node + linkType: hard + "@aws-sdk/config-resolver@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/config-resolver@npm:3.310.0" @@ -1722,6 +1964,34 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/core@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/core@npm:3.592.0" + dependencies: + "@smithy/core": ^2.2.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/signature-v4": ^3.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + fast-xml-parser: 4.2.5 + tslib: ^2.6.2 + checksum: 10ebbf695358e7bc3d2a84a7add3f52f479605c1ab6d2bd6970aa5846daebff2febf5156fbc5b275e0593c32d973a9f88f528df8280377557a48b87d1b9be5a3 + languageName: node + linkType: hard + +"@aws-sdk/credential-provider-cognito-identity@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/credential-provider-cognito-identity@npm:3.592.0" + dependencies: + "@aws-sdk/client-cognito-identity": 3.592.0 + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: b18700d445c4289634c91bda9a88391e5fd731bb4b34118be8dd9e1b1216f959829ae2f703a559bf88bceb755fe9962fb7a5acd874111f7d9e6c23c393d777f7 + languageName: node + linkType: hard + "@aws-sdk/credential-provider-env@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/credential-provider-env@npm:3.310.0" @@ -1792,6 +2062,18 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-env@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/credential-provider-env@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 3062e39c2b0e15eafea50fc2d182de41cba0c4845714b941dd7fb0b75605d7bae51d1919b2b1fdade0c3ec1e470d57ccb00d939898152ed1fbc2c2d265d400b1 + languageName: node + linkType: hard + "@aws-sdk/credential-provider-http@npm:3.582.0": version: 3.582.0 resolution: "@aws-sdk/credential-provider-http@npm:3.582.0" @@ -1809,6 +2091,23 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-http@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/credential-provider-http@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/fetch-http-handler": ^3.0.1 + "@smithy/node-http-handler": ^3.0.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/util-stream": ^3.0.1 + tslib: ^2.6.2 + checksum: d662174af1a9b3484ec0e5c176e66ea82f810dc53f865eca3b789bbb14e9d35ce6cf8d298d4e4ea972a91f08195bb27c13c9ce41b624ef8baaa2fb31d9c016ed + languageName: node + linkType: hard + "@aws-sdk/credential-provider-imds@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/credential-provider-imds@npm:3.310.0" @@ -1977,6 +2276,27 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-ini@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/credential-provider-ini@npm:3.592.0" + dependencies: + "@aws-sdk/credential-provider-env": 3.587.0 + "@aws-sdk/credential-provider-http": 3.587.0 + "@aws-sdk/credential-provider-process": 3.587.0 + "@aws-sdk/credential-provider-sso": 3.592.0 + "@aws-sdk/credential-provider-web-identity": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@smithy/credential-provider-imds": ^3.1.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + peerDependencies: + "@aws-sdk/client-sts": ^3.592.0 + checksum: 66b07abcfa6ead951d8d8bca9325c79438cec7737d141a978354ad07a4b646f09d71ec6adb84c8174e5045ae7f7fa4adef147bba130f4dc7806780d3d1a4df48 + languageName: node + linkType: hard + "@aws-sdk/credential-provider-node@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/credential-provider-node@npm:3.310.0" @@ -2107,6 +2427,26 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-node@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/credential-provider-node@npm:3.592.0" + dependencies: + "@aws-sdk/credential-provider-env": 3.587.0 + "@aws-sdk/credential-provider-http": 3.587.0 + "@aws-sdk/credential-provider-ini": 3.592.0 + "@aws-sdk/credential-provider-process": 3.587.0 + "@aws-sdk/credential-provider-sso": 3.592.0 + "@aws-sdk/credential-provider-web-identity": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@smithy/credential-provider-imds": ^3.1.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: c83bd0370250091d175c4b7f622f679d7ad48a98938b80c0c99fd243acd805b4eb54d3ab199cf6373645dd52b8b4b709e0e3a765a1c061d41043831f0962908b + languageName: node + linkType: hard + "@aws-sdk/credential-provider-node@npm:^3.388.0": version: 3.388.0 resolution: "@aws-sdk/credential-provider-node@npm:3.388.0" @@ -2202,6 +2542,19 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-process@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/credential-provider-process@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 20add2fa4ecb513a8f7c376284248bf16601af52d56f30a20b9cb6c77ed811162b2d1d0c364fe27bba50bc6ac1a395c50057351c1d2107837358ef3974d7ff9a + languageName: node + linkType: hard + "@aws-sdk/credential-provider-sso@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/credential-provider-sso@npm:3.310.0" @@ -2318,6 +2671,21 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-sso@npm:3.592.0": + version: 3.592.0 + resolution: "@aws-sdk/credential-provider-sso@npm:3.592.0" + dependencies: + "@aws-sdk/client-sso": 3.592.0 + "@aws-sdk/token-providers": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 5bc46040e521789a091b06d2d09931bd4254a3ece63f3370ec448cd58d0185821a39369efe47478cd6a0cd8911c4d93e52414ecca91ff72ed95b8813b619d93d + languageName: node + linkType: hard + "@aws-sdk/credential-provider-web-identity@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/credential-provider-web-identity@npm:3.310.0" @@ -2390,6 +2758,44 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/credential-provider-web-identity@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/credential-provider-web-identity@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + peerDependencies: + "@aws-sdk/client-sts": ^3.587.0 + checksum: bfade039dcf35041fc020832363840e8fd6d7e21afbab35945852f62bb718bc954a59cb78911ea3ce6f9aaca4184f4934ba269f713ff811d06fcef1332af8cba + languageName: node + linkType: hard + +"@aws-sdk/credential-providers@npm:^3.583.0": + version: 3.592.0 + resolution: "@aws-sdk/credential-providers@npm:3.592.0" + dependencies: + "@aws-sdk/client-cognito-identity": 3.592.0 + "@aws-sdk/client-sso": 3.592.0 + "@aws-sdk/client-sts": 3.592.0 + "@aws-sdk/credential-provider-cognito-identity": 3.592.0 + "@aws-sdk/credential-provider-env": 3.587.0 + "@aws-sdk/credential-provider-http": 3.587.0 + "@aws-sdk/credential-provider-ini": 3.592.0 + "@aws-sdk/credential-provider-node": 3.592.0 + "@aws-sdk/credential-provider-process": 3.587.0 + "@aws-sdk/credential-provider-sso": 3.592.0 + "@aws-sdk/credential-provider-web-identity": 3.587.0 + "@aws-sdk/types": 3.577.0 + "@smithy/credential-provider-imds": ^3.1.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 558122c1580eda3437b8e25f180660d1f890602930baf265059fa4d460e8928ff4fd5b7240268157ff562f2918992921336874b0ea36b06811c2b157c893bbb3 + languageName: node + linkType: hard + "@aws-sdk/endpoint-cache@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/endpoint-cache@npm:3.310.0" @@ -3292,6 +3698,19 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/middleware-user-agent@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/middleware-user-agent@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@aws-sdk/util-endpoints": 3.587.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 0a01579c20dc3e574e58578cf255169b7a8fc8cb2f38cd5d0d6ed282131d953d0ccd578d137a8d39c617b7722de7e194fce9647b662490935d5c8da01354ba5e + languageName: node + linkType: hard + "@aws-sdk/node-config-provider@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/node-config-provider@npm:3.310.0" @@ -3408,6 +3827,16 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/protocol-http@npm:^3.374.0": + version: 3.374.0 + resolution: "@aws-sdk/protocol-http@npm:3.374.0" + dependencies: + "@smithy/protocol-http": ^1.1.0 + tslib: ^2.5.0 + checksum: f8ec7ac8bb76b6efebb8b5fc37d32621d8c77b08daa137a879042c8f79e8de90521d80ae0f15350933ee637e1ea1df9ce8a12ab7870f265b5ecb1df0bfdbb8f6 + languageName: node + linkType: hard + "@aws-sdk/querystring-builder@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/querystring-builder@npm:3.310.0" @@ -3491,6 +3920,20 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/region-config-resolver@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/region-config-resolver@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + "@smithy/util-config-provider": ^3.0.0 + "@smithy/util-middleware": ^3.0.0 + tslib: ^2.6.2 + checksum: aa9bae8d88a7d3dc45017b8a6391942f70e95b4e16c4a6907048088f5eb49c9b77b81f084f4ed6d057eb4785ac182ee99dafa9cf3072d5aba3d19c02005abd8a + languageName: node + linkType: hard + "@aws-sdk/service-error-classification@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/service-error-classification@npm:3.310.0" @@ -3580,6 +4023,16 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/signature-v4@npm:^3.374.0": + version: 3.374.0 + resolution: "@aws-sdk/signature-v4@npm:3.374.0" + dependencies: + "@smithy/signature-v4": ^1.0.1 + tslib: ^2.5.0 + checksum: 7d8158a377ed220ff119682b1b850ff2c6c2ff1596cc487a63163cce914b0d3e63835b3df32de3550f938d0d4bca5c4664fe462a58c6da41396660a5a01d8f59 + languageName: node + linkType: hard + "@aws-sdk/smithy-client@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/smithy-client@npm:3.310.0" @@ -3826,6 +4279,21 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/token-providers@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/token-providers@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + peerDependencies: + "@aws-sdk/client-sso-oidc": ^3.587.0 + checksum: 7a4d44bc413b88b933b439c2b26ac7d55a0ad26ede6b774fc659e8fb7b7f4dee555c7e478aa304983c1f4cd696825b5c47171ec5b918d54bce0146849274088c + languageName: node + linkType: hard + "@aws-sdk/types@npm:3.310.0, @aws-sdk/types@npm:^3.222.0": version: 3.310.0 resolution: "@aws-sdk/types@npm:3.310.0" @@ -4151,6 +4619,18 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/util-endpoints@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/util-endpoints@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/types": ^3.0.0 + "@smithy/util-endpoints": ^2.0.1 + tslib: ^2.6.2 + checksum: 4b1cbfc49129b414144ad94cc947b78c6c3c061f5a39b4365d85c8a2d5e21b83ac85ab1add95b8eb64c48aed58792a486faa74887ff3a56a7a0f381bb1cbbce9 + languageName: node + linkType: hard + "@aws-sdk/util-hex-encoding@npm:3.310.0": version: 3.310.0 resolution: "@aws-sdk/util-hex-encoding@npm:3.310.0" @@ -4464,6 +4944,23 @@ __metadata: languageName: node linkType: hard +"@aws-sdk/util-user-agent-node@npm:3.587.0": + version: 3.587.0 + resolution: "@aws-sdk/util-user-agent-node@npm:3.587.0" + dependencies: + "@aws-sdk/types": 3.577.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + peerDependencies: + aws-crt: ">=1.0.0" + peerDependenciesMeta: + aws-crt: + optional: true + checksum: 6f963c5371de04144fbd2ed893d823bc7c9f9a9e6e40bde3a1bab82274213110b7e2542d7da0798ffa7d24031ff63b385b08799a07800a816f4c85b0c2e44abe + languageName: node + linkType: hard + "@aws-sdk/util-utf8-browser@npm:^3.0.0": version: 3.259.0 resolution: "@aws-sdk/util-utf8-browser@npm:3.259.0" @@ -9046,7 +9543,7 @@ __metadata: "@tsconfig/recommended": ^1.0.3 "@typescript-eslint/eslint-plugin": ^6.12.0 "@typescript-eslint/parser": ^6.12.0 - cohere-ai: ^7.9.3 + cohere-ai: ^7.10.5 dotenv: ^16.3.1 dpdm: ^3.12.0 eslint: ^8.33.0 @@ -11877,6 +12374,19 @@ __metadata: languageName: node linkType: hard +"@smithy/config-resolver@npm:^3.0.1": + version: 3.0.1 + resolution: "@smithy/config-resolver@npm:3.0.1" + dependencies: + "@smithy/node-config-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + "@smithy/util-config-provider": ^3.0.0 + "@smithy/util-middleware": ^3.0.0 + tslib: ^2.6.2 + checksum: b57650c31e230b9f9b961027d4c3b5b6d5728cbae3361df91f4da06389bbbecfe5a4483737d3d91abb6b3dd53cab9ead66be2f6386b558b6db1e247549363ba5 + languageName: node + linkType: hard + "@smithy/core@npm:^1.2.2": version: 1.2.2 resolution: "@smithy/core@npm:1.2.2" @@ -11909,6 +12419,22 @@ __metadata: languageName: node linkType: hard +"@smithy/core@npm:^2.2.0": + version: 2.2.0 + resolution: "@smithy/core@npm:2.2.0" + dependencies: + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-retry": ^3.0.3 + "@smithy/middleware-serde": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/util-middleware": ^3.0.0 + tslib: ^2.6.2 + checksum: 4b14ebbc6f9bcc54872bb19c42c3b7281c5e38af012e1278e4084433d720c310789219c1de4a1ea86398bfc080378faf1f95c506bf77df6cd109475658cb3f26 + languageName: node + linkType: hard + "@smithy/credential-provider-imds@npm:^2.0.0": version: 2.0.1 resolution: "@smithy/credential-provider-imds@npm:2.0.1" @@ -11974,6 +12500,31 @@ __metadata: languageName: node linkType: hard +"@smithy/credential-provider-imds@npm:^3.1.0": + version: 3.1.0 + resolution: "@smithy/credential-provider-imds@npm:3.1.0" + dependencies: + "@smithy/node-config-provider": ^3.1.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + tslib: ^2.6.2 + checksum: d13b08a15e7565efb848b30cda37dd9211c626bb6a7d9f4ec36da77732879a9708c90670a66185ed903c76e6b36665d429f01112bc46768fd272e3bf88ecd7d8 + languageName: node + linkType: hard + +"@smithy/eventstream-codec@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/eventstream-codec@npm:1.1.0" + dependencies: + "@aws-crypto/crc32": 3.0.0 + "@smithy/types": ^1.2.0 + "@smithy/util-hex-encoding": ^1.1.0 + tslib: ^2.5.0 + checksum: 88e414d9a758b88f28ddb669f1dc26f8d3e3a36d398adace3919a699ff289dbf0e0c59bed69dc85741a2bcf9cbe66ce803986ede548328a7117a711534e51c6b + languageName: node + linkType: hard + "@smithy/eventstream-codec@npm:^2.0.10": version: 2.0.10 resolution: "@smithy/eventstream-codec@npm:2.0.10" @@ -12316,6 +12867,15 @@ __metadata: languageName: node linkType: hard +"@smithy/is-array-buffer@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/is-array-buffer@npm:1.1.0" + dependencies: + tslib: ^2.5.0 + checksum: 39b2a177b5d98f1adb2e44c363be2f4f335b698e9803f5ffb4c6d32e5d51543f29daf90b9ee99d8833446561dfe1b8dc3464852970b90bb6c00655a425fc3ac2 + languageName: node + linkType: hard + "@smithy/is-array-buffer@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/is-array-buffer@npm:2.0.0" @@ -12434,6 +12994,21 @@ __metadata: languageName: node linkType: hard +"@smithy/middleware-endpoint@npm:^3.0.1": + version: 3.0.1 + resolution: "@smithy/middleware-endpoint@npm:3.0.1" + dependencies: + "@smithy/middleware-serde": ^3.0.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + "@smithy/url-parser": ^3.0.0 + "@smithy/util-middleware": ^3.0.0 + tslib: ^2.6.2 + checksum: e50858a46168368e8286e91f813ab77117aba16f4d778858bc43b2f42890e4566630858bc4dbb1a15c6c12e7706a806e0e8576db6b27c3ff8c3509fc495aa95f + languageName: node + linkType: hard + "@smithy/middleware-retry@npm:^2.0.13": version: 2.0.16 resolution: "@smithy/middleware-retry@npm:2.0.16" @@ -12499,6 +13074,23 @@ __metadata: languageName: node linkType: hard +"@smithy/middleware-retry@npm:^3.0.3": + version: 3.0.3 + resolution: "@smithy/middleware-retry@npm:3.0.3" + dependencies: + "@smithy/node-config-provider": ^3.1.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/service-error-classification": ^3.0.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + "@smithy/util-middleware": ^3.0.0 + "@smithy/util-retry": ^3.0.0 + tslib: ^2.6.2 + uuid: ^9.0.1 + checksum: ab499a129c901740f4c8372435029b466496bfba7b6f03e6e4b24a7bdad5fc82f0dce0401f1e425802e0fa6f90387a4303091c9a13d36e20c6e431d5fd7c63bc + languageName: node + linkType: hard + "@smithy/middleware-serde@npm:^2.0.10": version: 2.0.10 resolution: "@smithy/middleware-serde@npm:2.0.10" @@ -12670,6 +13262,18 @@ __metadata: languageName: node linkType: hard +"@smithy/node-config-provider@npm:^3.1.0": + version: 3.1.0 + resolution: "@smithy/node-config-provider@npm:3.1.0" + dependencies: + "@smithy/property-provider": ^3.1.0 + "@smithy/shared-ini-file-loader": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: b17afe28ec698faa8980e0bb9fd3bc44fd23c6b3b6f715bc0c9da2e2013249086d0ac7e6bedd61e90bd1ffc640591bf0439fd0fe65e9acf79464490e4ac3d074 + languageName: node + linkType: hard + "@smithy/node-http-handler@npm:^2.0.2, @smithy/node-http-handler@npm:^2.0.3": version: 2.0.3 resolution: "@smithy/node-http-handler@npm:2.0.3" @@ -12795,6 +13399,16 @@ __metadata: languageName: node linkType: hard +"@smithy/property-provider@npm:^3.1.0": + version: 3.1.0 + resolution: "@smithy/property-provider@npm:3.1.0" + dependencies: + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 28e9a705731ba93ca0f427a3932423b2539c7a48e7196c0f8cca1b8cfe7d3b7a02338d4eb007847a9b103fb54b5e8d9a4b76b5d29bcf852528144c6b2ebe8636 + languageName: node + linkType: hard + "@smithy/protocol-http@npm:^1.0.1": version: 1.1.0 resolution: "@smithy/protocol-http@npm:1.1.0" @@ -12805,6 +13419,16 @@ __metadata: languageName: node linkType: hard +"@smithy/protocol-http@npm:^1.1.0": + version: 1.2.0 + resolution: "@smithy/protocol-http@npm:1.2.0" + dependencies: + "@smithy/types": ^1.2.0 + tslib: ^2.5.0 + checksum: 39548762da6dbd301d36ef67709ef73ef6f9a4c9bdcc3fafa5d5625eec7dfa71db72898d3eb219a368a79ea5e368a08189519a7512d48e0cdc9db7089c8e9618 + languageName: node + linkType: hard + "@smithy/protocol-http@npm:^2.0.2, @smithy/protocol-http@npm:^2.0.3": version: 2.0.3 resolution: "@smithy/protocol-http@npm:2.0.3" @@ -13073,6 +13697,32 @@ __metadata: languageName: node linkType: hard +"@smithy/shared-ini-file-loader@npm:^3.1.0": + version: 3.1.0 + resolution: "@smithy/shared-ini-file-loader@npm:3.1.0" + dependencies: + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: ce75a158943e94c32d13cb5d262e06a5687482459329cc9e78cfcff459c33db6528c63cc74730c8cfe2367686b981c3dcc7f6acd555bde03bcf71a073f49fca0 + languageName: node + linkType: hard + +"@smithy/signature-v4@npm:^1.0.1": + version: 1.1.0 + resolution: "@smithy/signature-v4@npm:1.1.0" + dependencies: + "@smithy/eventstream-codec": ^1.1.0 + "@smithy/is-array-buffer": ^1.1.0 + "@smithy/types": ^1.2.0 + "@smithy/util-hex-encoding": ^1.1.0 + "@smithy/util-middleware": ^1.1.0 + "@smithy/util-uri-escape": ^1.1.0 + "@smithy/util-utf8": ^1.1.0 + tslib: ^2.5.0 + checksum: c9bcbf1eedb9d266643a091ba39410ce625e790d63e26785d11fec0b3e1e98b8e86fda1e4baaa1c79a52c17f4dfac15d6648a5c47243cffb04c9b0d465e8751a + languageName: node + linkType: hard + "@smithy/signature-v4@npm:^2.0.0, @smithy/signature-v4@npm:^2.0.10": version: 2.0.10 resolution: "@smithy/signature-v4@npm:2.0.10" @@ -13168,6 +13818,20 @@ __metadata: languageName: node linkType: hard +"@smithy/smithy-client@npm:^3.1.1": + version: 3.1.1 + resolution: "@smithy/smithy-client@npm:3.1.1" + dependencies: + "@smithy/middleware-endpoint": ^3.0.1 + "@smithy/middleware-stack": ^3.0.0 + "@smithy/protocol-http": ^4.0.0 + "@smithy/types": ^3.0.0 + "@smithy/util-stream": ^3.0.1 + tslib: ^2.6.2 + checksum: e579be9b1c96b4db8ab1841689b6f2c206fe44d4c33bc08c5e594f2eefe33c8e7fb6ee77c537de4a4fad53fe1efaccaa1497f11b6c340f38213bf562336d9fbc + languageName: node + linkType: hard + "@smithy/types@npm:^1.0.0, @smithy/types@npm:^1.1.0": version: 1.1.0 resolution: "@smithy/types@npm:1.1.0" @@ -13177,6 +13841,15 @@ __metadata: languageName: node linkType: hard +"@smithy/types@npm:^1.2.0": + version: 1.2.0 + resolution: "@smithy/types@npm:1.2.0" + dependencies: + tslib: ^2.5.0 + checksum: 376a1402d356a8dddd804af66ff2d273e57e332a3e9537a98039b47572684aae044d5fcd879ac6eee5cc08640ea00fbef0725a6a16026db5fb8d189473d44fe6 + languageName: node + linkType: hard + "@smithy/types@npm:^2.0.2": version: 2.0.2 resolution: "@smithy/types@npm:2.0.2" @@ -13391,6 +14064,16 @@ __metadata: languageName: node linkType: hard +"@smithy/util-buffer-from@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/util-buffer-from@npm:1.1.0" + dependencies: + "@smithy/is-array-buffer": ^1.1.0 + tslib: ^2.5.0 + checksum: 73b145d6a11754cb95d9fc21264dd7623855cb768b42db4465232b878c148d8b6c968c8d77bd836f28d0ce4c855f30814848e8533764ee587c6c7c0176e7582b + languageName: node + linkType: hard + "@smithy/util-buffer-from@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/util-buffer-from@npm:2.0.0" @@ -13489,6 +14172,19 @@ __metadata: languageName: node linkType: hard +"@smithy/util-defaults-mode-browser@npm:^3.0.3": + version: 3.0.3 + resolution: "@smithy/util-defaults-mode-browser@npm:3.0.3" + dependencies: + "@smithy/property-provider": ^3.1.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + bowser: ^2.11.0 + tslib: ^2.6.2 + checksum: 837559eb3a0519299bfe332db754f97d3fcab5ca91c993565fad8e98ce871e4345a9ba21a8e61c97c9f626ebb2728552745f234c6d97a9f7d51c09ad31fe19a9 + languageName: node + linkType: hard + "@smithy/util-defaults-mode-node@npm:^2.0.15": version: 2.0.18 resolution: "@smithy/util-defaults-mode-node@npm:2.0.18" @@ -13548,6 +14244,21 @@ __metadata: languageName: node linkType: hard +"@smithy/util-defaults-mode-node@npm:^3.0.3": + version: 3.0.3 + resolution: "@smithy/util-defaults-mode-node@npm:3.0.3" + dependencies: + "@smithy/config-resolver": ^3.0.1 + "@smithy/credential-provider-imds": ^3.1.0 + "@smithy/node-config-provider": ^3.1.0 + "@smithy/property-provider": ^3.1.0 + "@smithy/smithy-client": ^3.1.1 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 63c69f54475325809e998fd16d76357c36329f4dd77652071df467f6eae1d5b9e984a8eb2cb0d7d48122faec9076586c8787a1770b4b29d63835c1c4fa486de1 + languageName: node + linkType: hard + "@smithy/util-endpoints@npm:^1.0.8": version: 1.0.8 resolution: "@smithy/util-endpoints@npm:1.0.8" @@ -13570,6 +14281,26 @@ __metadata: languageName: node linkType: hard +"@smithy/util-endpoints@npm:^2.0.1": + version: 2.0.1 + resolution: "@smithy/util-endpoints@npm:2.0.1" + dependencies: + "@smithy/node-config-provider": ^3.1.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 1678dc438213079da97e202e1f101781d117c9f12c4e033670c652152dfd44fc0f9f4391e5e51833260635454d0621672c80f99ea1e1edd94bad6111d61d00cf + languageName: node + linkType: hard + +"@smithy/util-hex-encoding@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/util-hex-encoding@npm:1.1.0" + dependencies: + tslib: ^2.5.0 + checksum: e2647adbcd01660930d585ab34caca36c6d260127d63375a424de9bd36270b22fadfe7ac111155b9318cadbd43ce51034607f3f1c421deb56beb88839e629bf5 + languageName: node + linkType: hard + "@smithy/util-hex-encoding@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/util-hex-encoding@npm:2.0.0" @@ -13588,6 +14319,15 @@ __metadata: languageName: node linkType: hard +"@smithy/util-middleware@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/util-middleware@npm:1.1.0" + dependencies: + tslib: ^2.5.0 + checksum: 4c30f83355a2c455ec2d6ee8a1907c673a16955a33e8f220a2bb774f55310db1b1f9eea8c2760238916e04191ccb85583e91930e5710ba79e0be4dd4986940e8 + languageName: node + linkType: hard + "@smithy/util-middleware@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/util-middleware@npm:2.0.0" @@ -13771,6 +14511,15 @@ __metadata: languageName: node linkType: hard +"@smithy/util-uri-escape@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/util-uri-escape@npm:1.1.0" + dependencies: + tslib: ^2.5.0 + checksum: 17f02106e1d9875d4ab3b56e1fd7fffceec94a4632f265d3f6cc1d812d0ee208d9db3c3e0fd14025ea5993b503e84c0e3fda291ec4fb87719473e5e5116fb899 + languageName: node + linkType: hard + "@smithy/util-uri-escape@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/util-uri-escape@npm:2.0.0" @@ -13789,6 +14538,16 @@ __metadata: languageName: node linkType: hard +"@smithy/util-utf8@npm:^1.1.0": + version: 1.1.0 + resolution: "@smithy/util-utf8@npm:1.1.0" + dependencies: + "@smithy/util-buffer-from": ^1.1.0 + tslib: ^2.5.0 + checksum: 24216c8ce41cbb9455a4b33564c9a1b5c49dab77d7a0aa6f1daa71ada90ca82198ed48f9dda0d4a2c583e36e5259a4fb3b7584b3cf2983a1bfec440a7b303527 + languageName: node + linkType: hard + "@smithy/util-utf8@npm:^2.0.0": version: 2.0.0 resolution: "@smithy/util-utf8@npm:2.0.0" @@ -13819,6 +14578,17 @@ __metadata: languageName: node linkType: hard +"@smithy/util-waiter@npm:^3.0.0": + version: 3.0.0 + resolution: "@smithy/util-waiter@npm:3.0.0" + dependencies: + "@smithy/abort-controller": ^3.0.0 + "@smithy/types": ^3.0.0 + tslib: ^2.6.2 + checksum: 9e6aba7175abf6f96b2a15ece6ca1eb3a218bb494df0bb3a14c3e9bc59caf078ba5fe48e3a073d3f20ee65cb483f3b12e56808bfe1f094e28a21a3eceadfd045 + languageName: node + linkType: hard + "@spider-cloud/spider-client@npm:^0.0.21": version: 0.0.21 resolution: "@spider-cloud/spider-client@npm:0.0.21" @@ -18890,6 +19660,27 @@ __metadata: languageName: node linkType: hard +"cohere-ai@npm:^7.10.5": + version: 7.10.5 + resolution: "cohere-ai@npm:7.10.5" + dependencies: + "@aws-sdk/client-sagemaker": ^3.583.0 + "@aws-sdk/credential-providers": ^3.583.0 + "@aws-sdk/protocol-http": ^3.374.0 + "@aws-sdk/signature-v4": ^3.374.0 + form-data: 4.0.0 + form-data-encoder: ^4.0.2 + formdata-node: ^6.0.3 + js-base64: 3.7.2 + node-fetch: 2.7.0 + qs: 6.11.2 + readable-stream: ^4.5.2 + url-join: 4.0.1 + web-streams-polyfill: ^4.0.0 + checksum: 80f87d1bd831c0115936a9d9cd1a364bde184ad96d461396acb346e2d3601ef084b6736a1344553f6e05713b7e117a8c295ff508111fca9f7b6c2a16e722e035 + languageName: node + linkType: hard + "cohere-ai@npm:^7.9.3": version: 7.9.3 resolution: "cohere-ai@npm:7.9.3" @@ -23485,6 +24276,13 @@ __metadata: languageName: node linkType: hard +"form-data-encoder@npm:^4.0.2": + version: 4.0.2 + resolution: "form-data-encoder@npm:4.0.2" + checksum: 12769f21af2d750c20111f8a626560eaf613c2c62769d5924d9e5a44ba4ef52406f973844129151efd35533eb79ecf8e0b95b0839560e335204d2212efb9a9ef + languageName: node + linkType: hard + "form-data@npm:4.0.0, form-data@npm:^4.0.0": version: 4.0.0 resolution: "form-data@npm:4.0.0" @@ -23528,6 +24326,13 @@ __metadata: languageName: node linkType: hard +"formdata-node@npm:^6.0.3": + version: 6.0.3 + resolution: "formdata-node@npm:6.0.3" + checksum: 0c404dad51aac1e570bef1c20b702da9f4facac9db889398d333ca92a7ae4ab8c005ad249e2df184870fe388aedfe28fc81e8a0aabda7295a19316c1fbaf7407 + languageName: node + linkType: hard + "formdata-polyfill@npm:^4.0.10": version: 4.0.10 resolution: "formdata-polyfill@npm:4.0.10" @@ -33008,7 +33813,7 @@ __metadata: languageName: node linkType: hard -"readable-stream@npm:>=4.0.0": +"readable-stream@npm:>=4.0.0, readable-stream@npm:^4.5.2": version: 4.5.2 resolution: "readable-stream@npm:4.5.2" dependencies: @@ -37408,6 +38213,13 @@ __metadata: languageName: node linkType: hard +"web-streams-polyfill@npm:^4.0.0": + version: 4.0.0 + resolution: "web-streams-polyfill@npm:4.0.0" + checksum: df1abcb0f811621fa3ed95491c3d281eb7c82aa898b9759e47c3c9dffe73eb65c0459433da60a76a1ea08e6158c8b33fdf3a2ea2a44b9c4c252965507d54edc4 + languageName: node + linkType: hard + "web-worker@npm:^1.2.0": version: 1.3.0 resolution: "web-worker@npm:1.3.0" From 0290115f462d68970fc7538df29aedebc12ce809 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 12:59:04 -0700 Subject: [PATCH 02/24] chore: lint files --- libs/langchain-cohere/src/chat_models.ts | 12 ++++++------ .../src/tests/chat_models.int.test.ts | 2 +- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/libs/langchain-cohere/src/chat_models.ts b/libs/langchain-cohere/src/chat_models.ts index 0b0620217070..62ee87ca952e 100644 --- a/libs/langchain-cohere/src/chat_models.ts +++ b/libs/langchain-cohere/src/chat_models.ts @@ -248,10 +248,7 @@ export class ChatCohere< ); if (response.meta?.tokens) { - const { - inputTokens, - outputTokens, - } = response.meta.tokens; + const { inputTokens, outputTokens } = response.meta.tokens; if (outputTokens) { tokenUsage.completionTokens = @@ -262,7 +259,10 @@ export class ChatCohere< tokenUsage.promptTokens = (tokenUsage.promptTokens ?? 0) + inputTokens; } - tokenUsage.totalTokens = (tokenUsage.totalTokens ?? 0) + (tokenUsage.promptTokens ?? 0) + (tokenUsage.completionTokens ?? 0); + tokenUsage.totalTokens = + (tokenUsage.totalTokens ?? 0) + + (tokenUsage.promptTokens ?? 0) + + (tokenUsage.completionTokens ?? 0); } const generationInfo: Record = { ...response }; @@ -278,7 +278,7 @@ export class ChatCohere< input_tokens: tokenUsage.promptTokens ?? 0, output_tokens: tokenUsage.completionTokens ?? 0, total_tokens: tokenUsage.totalTokens ?? 0, - } + }, }), generationInfo, }, diff --git a/libs/langchain-cohere/src/tests/chat_models.int.test.ts b/libs/langchain-cohere/src/tests/chat_models.int.test.ts index e3c9332e3cbf..9c55abbd919c 100644 --- a/libs/langchain-cohere/src/tests/chat_models.int.test.ts +++ b/libs/langchain-cohere/src/tests/chat_models.int.test.ts @@ -86,7 +86,7 @@ test("Stream token count usage_metadata", async () => { ); }); -test.only("Invoke token count usage_metadata", async () => { +test("Invoke token count usage_metadata", async () => { const model = new ChatCohere({ model: "command-light", temperature: 0, From fc30a1091b3e624f9a0a234f6d3531c70c692e86 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:00:21 -0700 Subject: [PATCH 03/24] remove skipped token usage tests from cohere standard int test --- .../src/tests/chat_models.standard.int.test.ts | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/libs/langchain-cohere/src/tests/chat_models.standard.int.test.ts b/libs/langchain-cohere/src/tests/chat_models.standard.int.test.ts index 813aa00da412..ec47bbf4bf8b 100644 --- a/libs/langchain-cohere/src/tests/chat_models.standard.int.test.ts +++ b/libs/langchain-cohere/src/tests/chat_models.standard.int.test.ts @@ -21,22 +21,6 @@ class ChatCohereStandardIntegrationTests extends ChatModelIntegrationTests< constructorArgs: {}, }); } - - async testUsageMetadataStreaming() { - this.skipTestMessage( - "testUsageMetadataStreaming", - "ChatCohere", - "Streaming tokens is not currently supported." - ); - } - - async testUsageMetadata() { - this.skipTestMessage( - "testUsageMetadata", - "ChatCohere", - "Usage metadata tokens is not currently supported." - ); - } } const testClass = new ChatCohereStandardIntegrationTests(); From b38a8027f8bf5bf8f515f23d7baadcdb7620c11f Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:09:26 -0700 Subject: [PATCH 04/24] bump min core version to usage_metadata update --- libs/langchain-cohere/package.json | 2 +- yarn.lock | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/libs/langchain-cohere/package.json b/libs/langchain-cohere/package.json index 9f7ab1ce4641..be38f8f11e5d 100644 --- a/libs/langchain-cohere/package.json +++ b/libs/langchain-cohere/package.json @@ -35,7 +35,7 @@ "author": "LangChain", "license": "MIT", "dependencies": { - "@langchain/core": ">0.1.58 <0.3.0", + "@langchain/core": ">=0.2.5 <0.3.0", "cohere-ai": "^7.10.5" }, "devDependencies": { diff --git a/yarn.lock b/yarn.lock index 2e1d0b8c9f20..efb4d5ef6a13 100644 --- a/yarn.lock +++ b/yarn.lock @@ -9535,7 +9535,7 @@ __metadata: resolution: "@langchain/cohere@workspace:libs/langchain-cohere" dependencies: "@jest/globals": ^29.5.0 - "@langchain/core": ">0.1.58 <0.3.0" + "@langchain/core": ">=0.2.5 <0.3.0" "@langchain/scripts": ~0.0.14 "@langchain/standard-tests": 0.0.0 "@swc/core": ^1.3.90 From 448511e49a308f4a2a9acf9260b9ceb9b400df4a Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:19:58 -0700 Subject: [PATCH 05/24] add streamUsage --- libs/langchain-cohere/src/chat_models.ts | 26 +++++++++---- .../src/tests/chat_models.int.test.ts | 39 ++++++++++++++++++- 2 files changed, 57 insertions(+), 8 deletions(-) diff --git a/libs/langchain-cohere/src/chat_models.ts b/libs/langchain-cohere/src/chat_models.ts index 62ee87ca952e..73bcde88ebdc 100644 --- a/libs/langchain-cohere/src/chat_models.ts +++ b/libs/langchain-cohere/src/chat_models.ts @@ -47,6 +47,14 @@ export interface ChatCohereInput extends BaseChatModelParams { * @default {false} */ streaming?: boolean; + /** + * Whether or not to include token usage when streaming. + * This will include an extra chunk at the end of the stream + * with `eventType: "stream-end"` and the token usage in + * `usage_metadata`. + * @default {true} + */ + streamUsage?: boolean; } interface TokenUsage { @@ -58,7 +66,8 @@ interface TokenUsage { export interface CohereChatCallOptions extends BaseLanguageModelCallOptions, Partial>, - Partial> {} + Partial>, + Pick {} function convertMessagesToCohereMessages( messages: Array @@ -130,6 +139,8 @@ export class ChatCohere< streaming = false; + streamUsage: boolean = true; + constructor(fields?: ChatCohereInput) { super(fields ?? {}); @@ -144,6 +155,7 @@ export class ChatCohere< this.model = fields?.model ?? this.model; this.temperature = fields?.temperature ?? this.temperature; this.streaming = fields?.streaming ?? this.streaming; + this.streamUsage = fields?.streamUsage ?? this.streamUsage; } getLsParams(options: this["ParsedCallOptions"]): LangSmithParams { @@ -331,7 +343,9 @@ export class ChatCohere< if (chunk.eventType === "text-generation") { yield new ChatGenerationChunk({ text: chunk.text, - message: new AIMessageChunk({ content: chunk.text }), + message: new AIMessageChunk({ + content: chunk.text, + }), }); await runManager?.handleLLMNewToken(chunk.text); } else if (chunk.eventType !== "stream-end") { @@ -351,13 +365,11 @@ export class ChatCohere< }); } else if ( chunk.eventType === "stream-end" && - chunk.response.meta?.tokens && - (chunk.response.meta.tokens.inputTokens || - chunk.response.meta.tokens.outputTokens) + (this.streamUsage || options.streamUsage) ) { // stream-end events contain the final token count - const input_tokens = chunk.response.meta.tokens.inputTokens ?? 0; - const output_tokens = chunk.response.meta.tokens.outputTokens ?? 0; + const input_tokens = chunk.response.meta?.tokens?.inputTokens ?? 0; + const output_tokens = chunk.response.meta?.tokens?.outputTokens ?? 0; yield new ChatGenerationChunk({ text: "", message: new AIMessageChunk({ diff --git a/libs/langchain-cohere/src/tests/chat_models.int.test.ts b/libs/langchain-cohere/src/tests/chat_models.int.test.ts index 9c55abbd919c..6e87f9ba367e 100644 --- a/libs/langchain-cohere/src/tests/chat_models.int.test.ts +++ b/libs/langchain-cohere/src/tests/chat_models.int.test.ts @@ -59,12 +59,13 @@ test("should abort the request", async () => { }).rejects.toThrow("AbortError"); }); -test("Stream token count usage_metadata", async () => { +test.only("Stream token count usage_metadata", async () => { const model = new ChatCohere({ model: "command-light", temperature: 0, }); let res: AIMessageChunk | null = null; + let lastRes: AIMessageChunk | null = null; for await (const chunk of await model.stream( "Why is the sky blue? Be concise." )) { @@ -73,6 +74,7 @@ test("Stream token count usage_metadata", async () => { } else { res = res.concat(chunk); } + lastRes = chunk; } console.log(res); expect(res?.usage_metadata).toBeDefined(); @@ -84,6 +86,41 @@ test("Stream token count usage_metadata", async () => { expect(res.usage_metadata.total_tokens).toBe( res.usage_metadata.input_tokens + res.usage_metadata.output_tokens ); + expect(lastRes?.additional_kwargs).toBeDefined(); + if (!lastRes?.additional_kwargs) { + return; + } + expect(lastRes.additional_kwargs.eventType).toBe("stream-end"); +}); + +test.only("streamUsage excludes token usage", async () => { + const model = new ChatCohere({ + model: "command-light", + temperature: 0, + streamUsage: false, + }); + let res: AIMessageChunk | null = null; + let lastRes: AIMessageChunk | null = null; + for await (const chunk of await model.stream( + "Why is the sky blue? Be concise." + )) { + if (!res) { + res = chunk; + } else { + res = res.concat(chunk); + } + lastRes = chunk; + } + console.log(res); + expect(res?.usage_metadata).not.toBeDefined(); + if (res?.usage_metadata) { + return; + } + expect(lastRes?.additional_kwargs).toBeDefined(); + if (!lastRes?.additional_kwargs) { + return; + } + expect(lastRes.additional_kwargs.eventType).not.toBe("stream-end"); }); test("Invoke token count usage_metadata", async () => { From e28c29d24e9993b72a92b60aaa58a170d1937f37 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:24:32 -0700 Subject: [PATCH 06/24] added cohere to latest/lowest dep tests --- .github/workflows/compatibility.yml | 35 ++++++++++++++++++- dependency_range_tests/docker-compose.yml | 32 ++++++++++++++++- .../cohere/node/package.json | 9 +++++ .../cohere/node/update_resolutions_lowest.js | 22 ++++++++++++ .../with_standard_tests/cohere/node/yarn.lock | 22 ++++++++++++ .../cohere/test-with-latest-deps.sh | 22 ++++++++++++ .../cohere/test-with-lowest-deps.sh | 35 +++++++++++++++++++ 7 files changed, 175 insertions(+), 2 deletions(-) create mode 100644 dependency_range_tests/scripts/with_standard_tests/cohere/node/package.json create mode 100644 dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js create mode 100644 dependency_range_tests/scripts/with_standard_tests/cohere/node/yarn.lock create mode 100644 dependency_range_tests/scripts/with_standard_tests/cohere/test-with-latest-deps.sh create mode 100644 dependency_range_tests/scripts/with_standard_tests/cohere/test-with-lowest-deps.sh diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index cfe5447fa7d3..cdbd5c070fec 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -183,4 +183,37 @@ jobs: - name: Build `@langchain/standard-tests` run: yarn build --filter=@langchain/standard-tests - name: Test `@langchain/google-vertexai` with lowest deps - run: docker compose -f dependency_range_tests/docker-compose.yml run google-vertexai-lowest-deps \ No newline at end of file + run: docker compose -f dependency_range_tests/docker-compose.yml run google-vertexai-lowest-deps + + # Cohere + cohere-latest-deps: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Use Node.js ${{ env.NODE_VERSION }} + uses: actions/setup-node@v3 + with: + node-version: ${{ env.NODE_VERSION }} + cache: "yarn" + - name: Install dependencies + run: yarn install --immutable + - name: Build `@langchain/standard-tests` + run: yarn build --filter=@langchain/standard-tests + - name: Test `@langchain/cohere` with latest deps + run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-latest-deps + + cohere-lowest-deps: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: Use Node.js ${{ env.NODE_VERSION }} + uses: actions/setup-node@v3 + with: + node-version: ${{ env.NODE_VERSION }} + cache: "yarn" + - name: Install dependencies + run: yarn install --immutable + - name: Build `@langchain/standard-tests` + run: yarn build --filter=@langchain/standard-tests + - name: Test `@langchain/cohere` with lowest deps + run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-lowest-deps \ No newline at end of file diff --git a/dependency_range_tests/docker-compose.yml b/dependency_range_tests/docker-compose.yml index fbc7315d19fa..59728c2c970f 100644 --- a/dependency_range_tests/docker-compose.yml +++ b/dependency_range_tests/docker-compose.yml @@ -142,4 +142,34 @@ services: - ../libs/langchain-standard-tests:/libs/langchain-standard-tests - ../libs/langchain-google-vertexai:/libs/langchain-google-vertexai - ./scripts:/scripts - command: bash /scripts/with_standard_tests/google-vertexai/test-with-lowest-deps.sh \ No newline at end of file + command: bash /scripts/with_standard_tests/google-vertexai/test-with-lowest-deps.sh + + # Cohere + cohere-latest-deps: + image: node:18 + environment: + PUPPETEER_SKIP_DOWNLOAD: "true" + PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" + COHERE_API_KEY: ${COHERE_API_KEY} + working_dir: /app + volumes: + - ../turbo.json:/turbo.json + - ../package.json:/package.json + - ../libs/langchain-standard-tests:/libs/langchain-standard-tests + - ../libs/langchain-cohere:/libs/langchain-cohere + - ./scripts:/scripts + command: bash /scripts/with_standard_tests/cohere/test-with-latest-deps.sh + cohere-lowest-deps: + image: node:18 + environment: + PUPPETEER_SKIP_DOWNLOAD: "true" + PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" + COHERE_API_KEY: ${COHERE_API_KEY} + working_dir: /app + volumes: + - ../turbo.json:/turbo.json + - ../package.json:/package.json + - ../libs/langchain-standard-tests:/libs/langchain-standard-tests + - ../libs/langchain-cohere:/libs/langchain-cohere + - ./scripts:/scripts + command: bash /scripts/with_standard_tests/cohere/test-with-lowest-deps.sh \ No newline at end of file diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/node/package.json b/dependency_range_tests/scripts/with_standard_tests/cohere/node/package.json new file mode 100644 index 000000000000..a4622fc74597 --- /dev/null +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/node/package.json @@ -0,0 +1,9 @@ +{ + "name": "dependency-range-tests", + "version": "0.0.0", + "private": true, + "description": "Tests dependency ranges for LangChain.", + "dependencies": { + "semver": "^7.5.4" + } +} \ No newline at end of file diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js b/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js new file mode 100644 index 000000000000..8a9ea6687842 --- /dev/null +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js @@ -0,0 +1,22 @@ +const fs = require("fs"); +const semver = require("semver"); + +const communityPackageJsonPath = "/app/monorepo/libs/langchain-google-vertexai/package.json"; + +const currentPackageJson = JSON.parse(fs.readFileSync(communityPackageJsonPath)); + +if (currentPackageJson.dependencies["@langchain/core"] && !currentPackageJson.dependencies["@langchain/core"].includes("rc")) { + const minVersion = semver.minVersion( + currentPackageJson.dependencies["@langchain/core"] + ).version; + currentPackageJson.overrides = { + ...currentPackageJson.overrides, + "@langchain/core": minVersion, + }; + currentPackageJson.dependencies = { + ...currentPackageJson.dependencies, + "@langchain/core": minVersion, + }; +} + +fs.writeFileSync(communityPackageJsonPath, JSON.stringify(currentPackageJson, null, 2)); diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/node/yarn.lock b/dependency_range_tests/scripts/with_standard_tests/cohere/node/yarn.lock new file mode 100644 index 000000000000..50ac73caa812 --- /dev/null +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/node/yarn.lock @@ -0,0 +1,22 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +semver@^7.5.4: + version "7.5.4" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" + integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== + dependencies: + lru-cache "^6.0.0" + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-latest-deps.sh b/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-latest-deps.sh new file mode 100644 index 000000000000..0c7c23bd9793 --- /dev/null +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-latest-deps.sh @@ -0,0 +1,22 @@ +#!/usr/bin/env bash + +set -euxo pipefail + +export CI=true + +# New monorepo directory paths +monorepo_dir="/app/monorepo" +monorepo_openai_dir="/app/monorepo/libs/langchain-cohere" + +# Run the shared script to copy all necessary folders/files +bash /scripts/with_standard_tests/shared.sh cohere + +# Navigate back to monorepo root and install dependencies +cd "$monorepo_dir" +yarn + +# Navigate into `@langchain/cohere` to build and run tests +# We need to run inside the cohere directory so turbo repo does +# not try to build the package/its workspace dependencies. +cd "$monorepo_openai_dir" +yarn test diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-lowest-deps.sh b/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-lowest-deps.sh new file mode 100644 index 000000000000..7ec4bc0c2d84 --- /dev/null +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/test-with-lowest-deps.sh @@ -0,0 +1,35 @@ +#!/usr/bin/env bash + +set -euxo pipefail + +export CI=true + +monorepo_dir="/app/monorepo" +monorepo_cohere_dir="/app/monorepo/libs/langchain-cohere" +updater_script_dir="/app/updater_script" +updater_script_dir="/app/updater_script" +original_updater_script_dir="/scripts/with_standard_tests/cohere/node" + +# Run the shared script to copy all necessary folders/files +bash /scripts/with_standard_tests/shared.sh cohere + +# Copy the updater script to the monorepo +mkdir -p "$updater_script_dir" +cp "$original_updater_script_dir"/* "$updater_script_dir/" + +# Install deps (e.g semver) for the updater script +cd "$updater_script_dir" +yarn +# Run the updater script +node "update_resolutions_lowest.js" + + +# Navigate back to monorepo root and install dependencies +cd "$monorepo_dir" +yarn + +# Navigate into `@langchain/cohere` to build and run tests +# We need to run inside the cohere directory so turbo repo does +# not try to build the package/its workspace dependencies. +cd "$monorepo_cohere_dir" +yarn test From ddf98b1964ef051cc6fe21801562f69a359fa520 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:40:23 -0700 Subject: [PATCH 07/24] conditionally run latest/lowest --- .github/workflows/compatibility.yml | 50 ++++++++++++++++++++++++++++- 1 file changed, 49 insertions(+), 1 deletion(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index cdbd5c070fec..1c7a481fb1e1 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -4,9 +4,10 @@ on: push: branches: ["main"] pull_request: - # Do not run this workflow if only docs changed. + # Do not run this workflow if only docs/examples changed. paths-ignore: - 'docs/**' + - 'examples/**' workflow_dispatch: # Allows triggering the workflow manually in GitHub UI # If another push to the same PR or branch happens while this workflow is still running, @@ -31,6 +32,12 @@ jobs: # LangChain langchain-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'langchain') || + contains(github.event.pull_request.paths, 'langchain-core') || + contains(github.event.pull_request.paths, 'libs/langchain-openai') || + contains(github.event.pull_request.paths, 'libs/langchain-textsplitters')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -43,6 +50,9 @@ jobs: langchain-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'langchain') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -56,6 +66,11 @@ jobs: # Community community-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'libs/langchain-community') || + contains(github.event.pull_request.paths, 'langchain-core') || + contains(github.event.pull_request.paths, 'libs/langchain-openai')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -72,6 +87,9 @@ jobs: community-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'libs/langchain-community') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -89,6 +107,10 @@ jobs: # OpenAI openai-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'libs/langchain-openai') || + contains(github.event.pull_request.paths, 'langchain-core')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -105,6 +127,9 @@ jobs: openai-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'libs/langchain-openai') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -122,6 +147,10 @@ jobs: # Anthropic anthropic-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'libs/langchain-anthropic') || + contains(github.event.pull_request.paths, 'langchain-core')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -138,6 +167,9 @@ jobs: anthropic-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'libs/langchain-anthropic') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -155,6 +187,12 @@ jobs: # Google VertexAI google-vertexai-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'libs/langchain-google-vertexai') || + contains(github.event.pull_request.paths, 'langchain-core') || + contains(github.event.pull_request.paths, 'libs/langchain-google-gauth') || + contains(github.event.pull_request.paths, 'libs/langchain-google-common')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -171,6 +209,9 @@ jobs: google-vertexai-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'libs/langchain-google-vertexai') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -188,6 +229,10 @@ jobs: # Cohere cohere-latest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'libs/langchain-cohere') || + contains(github.event.pull_request.paths, 'langchain-core')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -204,6 +249,9 @@ jobs: cohere-lowest-deps: runs-on: ubuntu-latest + if: | + github.event_name == 'pull_request' && + contains(github.event.pull_request.paths, 'libs/langchain-cohere') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} From 8a4eaa6a8066a7530409f04080901b795862e8c9 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 15:46:18 -0700 Subject: [PATCH 08/24] nit --- .github/workflows/compatibility.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index 1c7a481fb1e1..60a394763e48 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -231,8 +231,8 @@ jobs: runs-on: ubuntu-latest if: | github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-cohere') || - contains(github.event.pull_request.paths, 'langchain-core')) + (contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') || + contains(github.event.pull_request.paths, 'langchain-core/**')) steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -251,7 +251,7 @@ jobs: runs-on: ubuntu-latest if: | github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-cohere') + contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} From 0127915d791b61664fb2ca9565b53246996e444f Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 15:47:32 -0700 Subject: [PATCH 09/24] cr --- libs/langchain-cohere/src/chat_models.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/libs/langchain-cohere/src/chat_models.ts b/libs/langchain-cohere/src/chat_models.ts index 73bcde88ebdc..cc8184a5bb05 100644 --- a/libs/langchain-cohere/src/chat_models.ts +++ b/libs/langchain-cohere/src/chat_models.ts @@ -38,7 +38,9 @@ export interface ChatCohereInput extends BaseChatModelParams { model?: string; /** * What sampling temperature to use, between 0.0 and 2.0. - * Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic. + * Higher values like 0.8 will make the output more random, + * while lower values like 0.2 will make it more focused + * and deterministic. * @default {0.3} */ temperature?: number; From 745aa151fe2027c83972a3908990cffe06793178 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 15:48:14 -0700 Subject: [PATCH 10/24] cr --- .github/workflows/compatibility.yml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index 60a394763e48..7a61051c49fe 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -249,9 +249,7 @@ jobs: cohere-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') + if: github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} From 87756a9c65b348c52b04faa92bb22a4b7f7a5ebb Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 15:49:21 -0700 Subject: [PATCH 11/24] cr --- .github/workflows/compatibility.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index 7a61051c49fe..ee2f7a9be9ee 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -16,9 +16,9 @@ on: # There's no point in testing an outdated version of the code. GitHub only allows # a limited number of job runners to be active at the same time, so it's better to cancel # pointless jobs early so that more useful jobs can run sooner. -concurrency: - group: exports-${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true +# concurrency: +# group: exports-${{ github.workflow }}-${{ github.ref }} +# cancel-in-progress: true env: PUPPETEER_SKIP_DOWNLOAD: "true" From f01e778bbfd188d76f74f9c535144aa4246c877c Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 15:50:01 -0700 Subject: [PATCH 12/24] revert --- .github/workflows/compatibility.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index ee2f7a9be9ee..7a61051c49fe 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -16,9 +16,9 @@ on: # There's no point in testing an outdated version of the code. GitHub only allows # a limited number of job runners to be active at the same time, so it's better to cancel # pointless jobs early so that more useful jobs can run sooner. -# concurrency: -# group: exports-${{ github.workflow }}-${{ github.ref }} -# cancel-in-progress: true +concurrency: + group: exports-${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true env: PUPPETEER_SKIP_DOWNLOAD: "true" From 427b0a20cf56fee49ccdd5555fa79fc57f443e76 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:05:09 -0700 Subject: [PATCH 13/24] test --- .github/workflows/test-compat.yml | 47 +++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 .github/workflows/test-compat.yml diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml new file mode 100644 index 000000000000..b55288310d2e --- /dev/null +++ b/.github/workflows/test-compat.yml @@ -0,0 +1,47 @@ +name: Dependency compatibility tests test + +on: + push: + branches: ["main"] + pull_request: + # Do not run this workflow if only docs/examples changed. + paths-ignore: + - 'docs/**' + - 'examples/**' + workflow_dispatch: # Allows triggering the workflow manually in GitHub UI + +# If another push to the same PR or branch happens while this workflow is still running, +# cancel the earlier run in favor of the next run. +# +# There's no point in testing an outdated version of the code. GitHub only allows +# a limited number of job runners to be active at the same time, so it's better to cancel +# pointless jobs early so that more useful jobs can run sooner. +concurrency: + group: exports-${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +env: + PUPPETEER_SKIP_DOWNLOAD: "true" + PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" + NODE_VERSION: "18.x" + COHERE_API_KEY: ${{ secrets.COHERE_API_KEY }} + +# Run a separate job for each check in the docker-compose file, +# so that they run in parallel instead of overwhelming the default 2 CPU runner. +jobs: + cohere-lowest-deps: + runs-on: ubuntu-latest + if: github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') + steps: + - uses: actions/checkout@v4 + - name: Use Node.js ${{ env.NODE_VERSION }} + uses: actions/setup-node@v3 + with: + node-version: ${{ env.NODE_VERSION }} + cache: "yarn" + - name: Install dependencies + run: yarn install --immutable + - name: Build `@langchain/standard-tests` + run: yarn build --filter=@langchain/standard-tests + - name: Test `@langchain/cohere` with lowest deps + run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-lowest-deps \ No newline at end of file From 8676b8828fec3a895edd284844780c7952e22438 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:06:13 -0700 Subject: [PATCH 14/24] try just pr --- .github/workflows/test-compat.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index b55288310d2e..cf6f884e7d27 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -28,10 +28,11 @@ env: # Run a separate job for each check in the docker-compose file, # so that they run in parallel instead of overwhelming the default 2 CPU runner. +# && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') jobs: cohere-lowest-deps: runs-on: ubuntu-latest - if: github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') + if: github.event_name == 'pull_request' steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} From 7ccce30f6b7ab7ba0c814b1c735875774ea4ced7 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:08:40 -0700 Subject: [PATCH 15/24] cr --- .github/workflows/test-compat.yml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index cf6f884e7d27..58c4095a3633 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -28,11 +28,10 @@ env: # Run a separate job for each check in the docker-compose file, # so that they run in parallel instead of overwhelming the default 2 CPU runner. -# && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') jobs: cohere-lowest-deps: runs-on: ubuntu-latest - if: github.event_name == 'pull_request' + if: ${{ github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') }} steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} From fe01ba5430a48ae91596b3bf37cdef15de80e1f3 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:09:35 -0700 Subject: [PATCH 16/24] cr --- .github/workflows/test-compat.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index 58c4095a3633..d58f312f457d 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -31,7 +31,7 @@ env: jobs: cohere-lowest-deps: runs-on: ubuntu-latest - if: ${{ github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') }} + if: ${{ github.event_name == 'pull_request' }} steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -41,6 +41,8 @@ jobs: cache: "yarn" - name: Install dependencies run: yarn install --immutable + - name: Log changed files + run: echo ${{ github.event.pull_request.paths }} - name: Build `@langchain/standard-tests` run: yarn build --filter=@langchain/standard-tests - name: Test `@langchain/cohere` with lowest deps From b586528d8e74fc5b8efd7f195bd555cde5821662 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:16:10 -0700 Subject: [PATCH 17/24] only log files --- .github/workflows/test-compat.yml | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index d58f312f457d..9c075d8f2d39 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -33,17 +33,17 @@ jobs: runs-on: ubuntu-latest if: ${{ github.event_name == 'pull_request' }} steps: - - uses: actions/checkout@v4 - - name: Use Node.js ${{ env.NODE_VERSION }} - uses: actions/setup-node@v3 - with: - node-version: ${{ env.NODE_VERSION }} - cache: "yarn" - - name: Install dependencies - run: yarn install --immutable - name: Log changed files - run: echo ${{ github.event.pull_request.paths }} - - name: Build `@langchain/standard-tests` - run: yarn build --filter=@langchain/standard-tests - - name: Test `@langchain/cohere` with lowest deps - run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-lowest-deps \ No newline at end of file + run: ${{ github.event.pull_request.paths }} + # - uses: actions/checkout@v4 + # - name: Use Node.js ${{ env.NODE_VERSION }} + # uses: actions/setup-node@v3 + # with: + # node-version: ${{ env.NODE_VERSION }} + # cache: "yarn" + # - name: Install dependencies + # run: yarn install --immutable + # - name: Build `@langchain/standard-tests` + # run: yarn build --filter=@langchain/standard-tests + # - name: Test `@langchain/cohere` with lowest deps + # run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-lowest-deps \ No newline at end of file From 8f22a96fd91ec0a05b3cdd4eb0e1b71a6c13d7b7 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:18:53 -0700 Subject: [PATCH 18/24] more tests --- .github/workflows/test-compat.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index 9c075d8f2d39..c89447db89d2 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -34,7 +34,7 @@ jobs: if: ${{ github.event_name == 'pull_request' }} steps: - name: Log changed files - run: ${{ github.event.pull_request.paths }} + run: echo "${{ github.event.pull_request }}" && echo "${{ contains(github.event.pull_request.paths, 'libs/**') }}" && echo "${{ contains(github.event.pull_request.paths, 'libs/langchain-cohere') }}" # - uses: actions/checkout@v4 # - name: Use Node.js ${{ env.NODE_VERSION }} # uses: actions/setup-node@v3 From e9d481715e430825f52dfe23929f97373afa8e6e Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:20:02 -0700 Subject: [PATCH 19/24] toJson --- .github/workflows/test-compat.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index c89447db89d2..5545128ce72f 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -34,7 +34,7 @@ jobs: if: ${{ github.event_name == 'pull_request' }} steps: - name: Log changed files - run: echo "${{ github.event.pull_request }}" && echo "${{ contains(github.event.pull_request.paths, 'libs/**') }}" && echo "${{ contains(github.event.pull_request.paths, 'libs/langchain-cohere') }}" + run: echo "${{ toJSON(github.event.pull_request) }}" # - uses: actions/checkout@v4 # - name: Use Node.js ${{ env.NODE_VERSION }} # uses: actions/setup-node@v3 From bb17fe5b38bdb273c1f8b068650c4119e61d3783 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 16:23:26 -0700 Subject: [PATCH 20/24] use git to access changed files --- .github/workflows/test-compat.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml index 5545128ce72f..d892e714ceb6 100644 --- a/.github/workflows/test-compat.yml +++ b/.github/workflows/test-compat.yml @@ -33,8 +33,10 @@ jobs: runs-on: ubuntu-latest if: ${{ github.event_name == 'pull_request' }} steps: + - name: Git diff + run: git diff --name-only -r HEAD^1 HEAD - name: Log changed files - run: echo "${{ toJSON(github.event.pull_request) }}" + run: echo "${{ contains(git diff --name-only -r HEAD^1 HEAD, 'libs/langchain-cohere') }}" # - uses: actions/checkout@v4 # - name: Use Node.js ${{ env.NODE_VERSION }} # uses: actions/setup-node@v3 From 5331f45525f96c9605d0a08941e8a8f1d0cde472 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:31:18 -0700 Subject: [PATCH 21/24] fix if statements --- .github/workflows/compatibility.yml | 85 ++++++++++++++--------------- .github/workflows/test-compat.yml | 51 ----------------- 2 files changed, 40 insertions(+), 96 deletions(-) delete mode 100644 .github/workflows/test-compat.yml diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index 7a61051c49fe..90d483649f63 100644 --- a/.github/workflows/compatibility.yml +++ b/.github/workflows/compatibility.yml @@ -29,15 +29,27 @@ env: # Run a separate job for each check in the docker-compose file, # so that they run in parallel instead of overwhelming the default 2 CPU runner. jobs: + get-changed-files: + runs-on: ubuntu-latest + outputs: + changed_files: ${{ steps.get_changes.outputs.changed_files }} + steps: + - name: Checkout + uses: actions/checkout@v3 + with: + fetch-depth: 2 + - name: Get changes + id: get_changes + run: | + echo "changed_files<> $GITHUB_OUTPUT + git diff --name-only -r HEAD^1 HEAD | while read line; do printf "%s\n" "$line"; done >> $GITHUB_OUTPUT + echo "EOF" >> $GITHUB_OUTPUT + # LangChain langchain-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'langchain') || - contains(github.event.pull_request.paths, 'langchain-core') || - contains(github.event.pull_request.paths, 'libs/langchain-openai') || - contains(github.event.pull_request.paths, 'libs/langchain-textsplitters')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain/') || contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-openai/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-textsplitters/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -50,9 +62,8 @@ jobs: langchain-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'langchain') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -66,11 +77,8 @@ jobs: # Community community-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-community') || - contains(github.event.pull_request.paths, 'langchain-core') || - contains(github.event.pull_request.paths, 'libs/langchain-openai')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-openai/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-community/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -87,9 +95,8 @@ jobs: community-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-community') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-community/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -107,10 +114,8 @@ jobs: # OpenAI openai-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-openai') || - contains(github.event.pull_request.paths, 'langchain-core')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-openai/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -127,9 +132,8 @@ jobs: openai-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-openai') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-openai/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -147,10 +151,8 @@ jobs: # Anthropic anthropic-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-anthropic') || - contains(github.event.pull_request.paths, 'langchain-core')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-anthropic/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -167,9 +169,8 @@ jobs: anthropic-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-anthropic') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-anthropic/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -187,12 +188,8 @@ jobs: # Google VertexAI google-vertexai-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-google-vertexai') || - contains(github.event.pull_request.paths, 'langchain-core') || - contains(github.event.pull_request.paths, 'libs/langchain-google-gauth') || - contains(github.event.pull_request.paths, 'libs/langchain-google-common')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-google-vertexai/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-google-gauth/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-google-common/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -209,9 +206,8 @@ jobs: google-vertexai-lowest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - contains(github.event.pull_request.paths, 'libs/langchain-google-vertexai') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-google-vertexai/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -229,10 +225,8 @@ jobs: # Cohere cohere-latest-deps: runs-on: ubuntu-latest - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') || - contains(github.event.pull_request.paths, 'langchain-core/**')) + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-cohere/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} @@ -249,7 +243,8 @@ jobs: cohere-lowest-deps: runs-on: ubuntu-latest - if: github.event_name == 'pull_request' && contains(github.event.pull_request.paths, 'libs/langchain-cohere/**') + needs: get-changed-files + if: contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-cohere/') steps: - uses: actions/checkout@v4 - name: Use Node.js ${{ env.NODE_VERSION }} diff --git a/.github/workflows/test-compat.yml b/.github/workflows/test-compat.yml deleted file mode 100644 index d892e714ceb6..000000000000 --- a/.github/workflows/test-compat.yml +++ /dev/null @@ -1,51 +0,0 @@ -name: Dependency compatibility tests test - -on: - push: - branches: ["main"] - pull_request: - # Do not run this workflow if only docs/examples changed. - paths-ignore: - - 'docs/**' - - 'examples/**' - workflow_dispatch: # Allows triggering the workflow manually in GitHub UI - -# If another push to the same PR or branch happens while this workflow is still running, -# cancel the earlier run in favor of the next run. -# -# There's no point in testing an outdated version of the code. GitHub only allows -# a limited number of job runners to be active at the same time, so it's better to cancel -# pointless jobs early so that more useful jobs can run sooner. -concurrency: - group: exports-${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true - -env: - PUPPETEER_SKIP_DOWNLOAD: "true" - PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" - NODE_VERSION: "18.x" - COHERE_API_KEY: ${{ secrets.COHERE_API_KEY }} - -# Run a separate job for each check in the docker-compose file, -# so that they run in parallel instead of overwhelming the default 2 CPU runner. -jobs: - cohere-lowest-deps: - runs-on: ubuntu-latest - if: ${{ github.event_name == 'pull_request' }} - steps: - - name: Git diff - run: git diff --name-only -r HEAD^1 HEAD - - name: Log changed files - run: echo "${{ contains(git diff --name-only -r HEAD^1 HEAD, 'libs/langchain-cohere') }}" - # - uses: actions/checkout@v4 - # - name: Use Node.js ${{ env.NODE_VERSION }} - # uses: actions/setup-node@v3 - # with: - # node-version: ${{ env.NODE_VERSION }} - # cache: "yarn" - # - name: Install dependencies - # run: yarn install --immutable - # - name: Build `@langchain/standard-tests` - # run: yarn build --filter=@langchain/standard-tests - # - name: Test `@langchain/cohere` with lowest deps - # run: docker compose -f dependency_range_tests/docker-compose.yml run cohere-lowest-deps \ No newline at end of file From 2a8632e5a30b0acd9c1e36cbe524ac7e8517ae2f Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:38:19 -0700 Subject: [PATCH 22/24] fix test --- .../cohere/node/update_resolutions_lowest.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js b/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js index 8a9ea6687842..4f349584032b 100644 --- a/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js +++ b/dependency_range_tests/scripts/with_standard_tests/cohere/node/update_resolutions_lowest.js @@ -1,7 +1,7 @@ const fs = require("fs"); const semver = require("semver"); -const communityPackageJsonPath = "/app/monorepo/libs/langchain-google-vertexai/package.json"; +const communityPackageJsonPath = "/app/monorepo/libs/langchain-cohere/package.json"; const currentPackageJson = JSON.parse(fs.readFileSync(communityPackageJsonPath)); From 3060a41aabf2d5a8c73da71563c5cbb00c5646e0 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 12:32:14 -0700 Subject: [PATCH 23/24] unfocus jest tests and add eslint rule --- libs/langchain-cohere/.eslintrc.cjs | 1 + libs/langchain-cohere/src/tests/chat_models.int.test.ts | 4 ++-- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/libs/langchain-cohere/.eslintrc.cjs b/libs/langchain-cohere/.eslintrc.cjs index 6503be533320..bf76a7f0a6c2 100644 --- a/libs/langchain-cohere/.eslintrc.cjs +++ b/libs/langchain-cohere/.eslintrc.cjs @@ -61,6 +61,7 @@ module.exports = { "func-names": 0, "no-lonely-if": 0, "prefer-rest-params": 0, + 'jest/no-focused-tests': 'error', "new-cap": ["error", { properties: false, capIsNew: false }], }, overrides: [ diff --git a/libs/langchain-cohere/src/tests/chat_models.int.test.ts b/libs/langchain-cohere/src/tests/chat_models.int.test.ts index 6e87f9ba367e..75fe1864d2a5 100644 --- a/libs/langchain-cohere/src/tests/chat_models.int.test.ts +++ b/libs/langchain-cohere/src/tests/chat_models.int.test.ts @@ -59,7 +59,7 @@ test("should abort the request", async () => { }).rejects.toThrow("AbortError"); }); -test.only("Stream token count usage_metadata", async () => { +test("Stream token count usage_metadata", async () => { const model = new ChatCohere({ model: "command-light", temperature: 0, @@ -93,7 +93,7 @@ test.only("Stream token count usage_metadata", async () => { expect(lastRes.additional_kwargs.eventType).toBe("stream-end"); }); -test.only("streamUsage excludes token usage", async () => { +test("streamUsage excludes token usage", async () => { const model = new ChatCohere({ model: "command-light", temperature: 0, From 018aa93a071925f0b4a859576ba7f94e291cd160 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 14:48:00 -0700 Subject: [PATCH 24/24] add eslint-plugin-jest --- libs/langchain-cohere/.eslintrc.cjs | 2 +- libs/langchain-cohere/package.json | 1 + yarn.lock | 1 + 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/libs/langchain-cohere/.eslintrc.cjs b/libs/langchain-cohere/.eslintrc.cjs index bf76a7f0a6c2..d533e6deffb6 100644 --- a/libs/langchain-cohere/.eslintrc.cjs +++ b/libs/langchain-cohere/.eslintrc.cjs @@ -11,7 +11,7 @@ module.exports = { project: "./tsconfig.json", sourceType: "module", }, - plugins: ["@typescript-eslint", "no-instanceof"], + plugins: ["@typescript-eslint", "no-instanceof", "eslint-plugin-jest"], ignorePatterns: [ ".eslintrc.cjs", "scripts", diff --git a/libs/langchain-cohere/package.json b/libs/langchain-cohere/package.json index be38f8f11e5d..1e39467ebe17 100644 --- a/libs/langchain-cohere/package.json +++ b/libs/langchain-cohere/package.json @@ -53,6 +53,7 @@ "eslint-config-airbnb-base": "^15.0.0", "eslint-config-prettier": "^8.6.0", "eslint-plugin-import": "^2.27.5", + "eslint-plugin-jest": "^27.6.0", "eslint-plugin-no-instanceof": "^1.0.1", "eslint-plugin-prettier": "^4.2.1", "jest": "^29.5.0", diff --git a/yarn.lock b/yarn.lock index fb5e51d7b23c..2d33838f76e7 100644 --- a/yarn.lock +++ b/yarn.lock @@ -9550,6 +9550,7 @@ __metadata: eslint-config-airbnb-base: ^15.0.0 eslint-config-prettier: ^8.6.0 eslint-plugin-import: ^2.27.5 + eslint-plugin-jest: ^27.6.0 eslint-plugin-no-instanceof: ^1.0.1 eslint-plugin-prettier: ^4.2.1 jest: ^29.5.0