From e908bfd5cd8654879167c3fa5e125265eaec67df Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:38:50 -0700 Subject: [PATCH 01/11] ci[patch]: Only run latest/lowest if specific package touched --- .github/workflows/compatibility.yml | 43 ++++++++++++++++++++++++++++- 1 file changed, 42 insertions(+), 1 deletion(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index cfe5447fa7d3..985812cdb219 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 }} From dd3f8a33047c990bacb4fc6d55f55b3ee9af53ff Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 13:57:10 -0700 Subject: [PATCH 02/11] matrix it! --- .../unit-tests-langchain-community.yml | 54 ------------------- .../unit-tests-langchain-integrations.yml | 10 ++-- turbo.json | 2 +- 3 files changed, 8 insertions(+), 58 deletions(-) delete mode 100644 .github/workflows/unit-tests-langchain-community.yml diff --git a/.github/workflows/unit-tests-langchain-community.yml b/.github/workflows/unit-tests-langchain-community.yml deleted file mode 100644 index 0d3dc85f9f9d..000000000000 --- a/.github/workflows/unit-tests-langchain-community.yml +++ /dev/null @@ -1,54 +0,0 @@ -# This workflow will do a clean installation of node dependencies, cache/restore them, build the source code and run tests across different versions of node -# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-nodejs - -name: Unit Tests (LangChain Community) - -on: - push: - branches: ["main"] - pull_request: - # Only run when LangChain Core, or Community code changes. - paths: - - 'langchain-core/**' - - 'libs/langchain-community/**' - 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: ${{ github.workflow }}-${{ github.ref }} - cancel-in-progress: true - -jobs: - unit-tests: - name: Unit Tests - strategy: - matrix: - os: [ubuntu-latest] - node-version: [18.x, 20.x] - # See Node.js release schedule at https://nodejs.org/en/about/releases/ - # include: - # - os: windows-latest - # node-version: 20.x - # - os: macos-latest - # node-version: 20.x - runs-on: ${{ matrix.os }} - env: - PUPPETEER_SKIP_DOWNLOAD: "true" - PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" - steps: - - uses: actions/checkout@v4 - - name: Use Node.js ${{ matrix.node-version }} - uses: actions/setup-node@v3 - with: - node-version: ${{ matrix.node-version }} - cache: "yarn" - - name: Install dependencies - run: yarn install --immutable - - name: Test - run: yarn run test:unit:ci --filter=@langchain/community diff --git a/.github/workflows/unit-tests-langchain-integrations.yml b/.github/workflows/unit-tests-langchain-integrations.yml index b3782d02ba27..b37b8950af3a 100644 --- a/.github/workflows/unit-tests-langchain-integrations.yml +++ b/.github/workflows/unit-tests-langchain-integrations.yml @@ -11,7 +11,6 @@ on: paths: - 'langchain-core/**' - 'libs/**/**' - - '!libs/langchain-community/**' workflow_dispatch: # Allows triggering the workflow manually in GitHub UI @@ -32,6 +31,7 @@ jobs: matrix: os: [ubuntu-latest] node-version: [18.x, 20.x] + package: [anthropic, azure-openai, cloudflare, cohere, community, exa, google-common, google-gauth, google-genai, google-vertexai, google-vertexai-web, google-webauth, groq, mistralai, mongo, nomic, openai, pinecone, qdrant, redis, textsplitters, weaviate, yandex] # See Node.js release schedule at https://nodejs.org/en/about/releases/ # include: # - os: windows-latest @@ -39,6 +39,10 @@ jobs: # - os: macos-latest # node-version: 20.x runs-on: ${{ matrix.os }} + if: | + github.event_name == 'pull_request' && + (contains(github.event.pull_request.paths, 'langchain-core') || + contains(github.event.pull_request.paths, 'libs/langchain-${{ matrix.package }}')) env: PUPPETEER_SKIP_DOWNLOAD: "true" PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" @@ -51,5 +55,5 @@ jobs: cache: "yarn" - name: Install dependencies run: yarn install --immutable - - name: Test - run: yarn run test:unit:ci --filter=!@langchain/community --filter=!@langchain/core --filter=!langchain --filter=!api_refs --filter=!core_docs --filter=!create-langchain-integration --filter=!examples + - name: Test '@langchain/${{ matrix.package }}' package + run: yarn test:unit:ci --filter=@langchain/${{ matrix.package }} diff --git a/turbo.json b/turbo.json index f69adb6cf3dc..6fbd6d60e925 100644 --- a/turbo.json +++ b/turbo.json @@ -24,7 +24,7 @@ }, "test:ci": { "outputs": [], - "dependsOn": ["test"] + "dependsOn": ["^test", "test"] }, "test:single": { "dependsOn": ["^build", "build"] From 4865bf903e87dfd5d8ae0a4a2fdee95f2bd8e8ac Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 14:05:27 -0700 Subject: [PATCH 03/11] docs for new integration ci testsing --- ...-integrations.yml => unit-tests-integrations.yml} | 0 CONTRIBUTING.md | 12 ++++++++++++ 2 files changed, 12 insertions(+) rename .github/workflows/{unit-tests-langchain-integrations.yml => unit-tests-integrations.yml} (100%) diff --git a/.github/workflows/unit-tests-langchain-integrations.yml b/.github/workflows/unit-tests-integrations.yml similarity index 100% rename from .github/workflows/unit-tests-langchain-integrations.yml rename to .github/workflows/unit-tests-integrations.yml diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index a07aacf4e240..4837a05c94c4 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -37,6 +37,18 @@ To make creating packages like this easier, we offer the [`create-langchain-inte $ npx create-langchain-integration ``` +After creating the new integration package, you should add it to the [`unit-tests-integrations.yml`](./.github/workflows/unit-tests-integrations.yml) GitHub action workflow so that it is tested in CI. To do this, simply add the integration name inside the `jobs.unit-tests.strategy.matrix.package` array: + +```yaml +jobs: + unit-tests: + name: Unit Tests + strategy: + matrix: + package: [anthropic, azure-openai, cloudflare, ] + ... +``` + ### Want to add a feature that's already in Python? If you're interested in contributing a feature that's already in the [LangChain Python repo](https://github.com/langchain-ai/langchain) and you'd like some help getting started, you can try pasting code snippets and classes into the [LangChain Python to JS translator](https://langchain-translator.vercel.app/). From a2f56c1eefc0e78aeb8aa52da8f79e5dae4b86ae Mon Sep 17 00:00:00 2001 From: bracesproul Date: Tue, 11 Jun 2024 14:06:07 -0700 Subject: [PATCH 04/11] make change to core to test --- langchain-core/src/prompts/chat.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/langchain-core/src/prompts/chat.ts b/langchain-core/src/prompts/chat.ts index 66c5d6c61839..2f3e53529ac2 100644 --- a/langchain-core/src/prompts/chat.ts +++ b/langchain-core/src/prompts/chat.ts @@ -1,5 +1,6 @@ // Default generic "any" values are for backwards compatibility. // Replace with "string" when we are comfortable with a breaking change. +// todo: remove me import type { BaseCallbackConfig } from "../callbacks/manager.js"; import { From 85e62b0e9aac3c991e5935eee654c1460f042667 Mon Sep 17 00:00:00 2001 From: Jacob Lee Date: Tue, 11 Jun 2024 17:01:57 -0700 Subject: [PATCH 05/11] Update chat.ts --- langchain-core/src/prompts/chat.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/langchain-core/src/prompts/chat.ts b/langchain-core/src/prompts/chat.ts index 2f3e53529ac2..66c5d6c61839 100644 --- a/langchain-core/src/prompts/chat.ts +++ b/langchain-core/src/prompts/chat.ts @@ -1,6 +1,5 @@ // Default generic "any" values are for backwards compatibility. // Replace with "string" when we are comfortable with a breaking change. -// todo: remove me import type { BaseCallbackConfig } from "../callbacks/manager.js"; import { From 84a3ef16ba5456cc265775eb233518a8d74a0649 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:33:28 -0700 Subject: [PATCH 06/11] fix if statements --- .github/workflows/compatibility.yml | 78 ++++++++++++++--------------- 1 file changed, 37 insertions(+), 41 deletions(-) diff --git a/.github/workflows/compatibility.yml b/.github/workflows/compatibility.yml index 985812cdb219..034fdfd03a73 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 }} @@ -224,4 +220,4 @@ 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 From a9004f10a85cc552880e829fa0c67c1f35e0a26b Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:35:20 -0700 Subject: [PATCH 07/11] fix if integrations --- .github/workflows/unit-tests-integrations.yml | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/.github/workflows/unit-tests-integrations.yml b/.github/workflows/unit-tests-integrations.yml index b37b8950af3a..03aed75005a6 100644 --- a/.github/workflows/unit-tests-integrations.yml +++ b/.github/workflows/unit-tests-integrations.yml @@ -25,6 +25,22 @@ concurrency: cancel-in-progress: true 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 + unit-tests: name: Unit Tests strategy: @@ -39,10 +55,7 @@ jobs: # - os: macos-latest # node-version: 20.x runs-on: ${{ matrix.os }} - if: | - github.event_name == 'pull_request' && - (contains(github.event.pull_request.paths, 'langchain-core') || - contains(github.event.pull_request.paths, 'libs/langchain-${{ matrix.package }}')) + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-${{ matrix.package }}/') env: PUPPETEER_SKIP_DOWNLOAD: "true" PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "true" From 7df2fd5cd4fd6f475fad0d10bca3a3fbc7588769 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:37:12 -0700 Subject: [PATCH 08/11] test --- libs/langchain-textsplitters/src/text_splitter.ts | 3 +++ 1 file changed, 3 insertions(+) diff --git a/libs/langchain-textsplitters/src/text_splitter.ts b/libs/langchain-textsplitters/src/text_splitter.ts index 095ea3e796ca..898095d5bfd5 100644 --- a/libs/langchain-textsplitters/src/text_splitter.ts +++ b/libs/langchain-textsplitters/src/text_splitter.ts @@ -3,6 +3,9 @@ import { Document, BaseDocumentTransformer } from "@langchain/core/documents"; import { getEncoding } from "@langchain/core/utils/tiktoken"; export interface TextSplitterParams { + /** + * todo drop me + */ chunkSize: number; chunkOverlap: number; keepSeparator: boolean; From b480cd184cd7c31a86943e83cd21613de7e6800b Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:39:21 -0700 Subject: [PATCH 09/11] revert --- libs/langchain-textsplitters/src/text_splitter.ts | 3 --- 1 file changed, 3 deletions(-) diff --git a/libs/langchain-textsplitters/src/text_splitter.ts b/libs/langchain-textsplitters/src/text_splitter.ts index 898095d5bfd5..095ea3e796ca 100644 --- a/libs/langchain-textsplitters/src/text_splitter.ts +++ b/libs/langchain-textsplitters/src/text_splitter.ts @@ -3,9 +3,6 @@ import { Document, BaseDocumentTransformer } from "@langchain/core/documents"; import { getEncoding } from "@langchain/core/utils/tiktoken"; export interface TextSplitterParams { - /** - * todo drop me - */ chunkSize: number; chunkOverlap: number; keepSeparator: boolean; From fa64ad19c953724ff7a7c0db8536ab0a994cad88 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:45:13 -0700 Subject: [PATCH 10/11] conditionally run test exports --- .github/workflows/test-exports.yml | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/.github/workflows/test-exports.yml b/.github/workflows/test-exports.yml index 22c46d2acb8e..44bf3864216e 100644 --- a/.github/workflows/test-exports.yml +++ b/.github/workflows/test-exports.yml @@ -1,6 +1,15 @@ name: Environment tests on: + pull_request: + # Only run workflow if files in these directories are changed + paths: + - 'langchain/**' + - 'langchain-core/**' + - 'libs/langchain-anthropic/**' + - 'libs/langchain-community/**' + - 'libs/langchain-openai/**' + - 'examples/**' workflow_dispatch: # Allows triggering the workflow manually in GitHub UI workflow_call: # Allows triggering the workflow from another workflow From 2eca3e218d7392881ff95a1222540cef00e49093 Mon Sep 17 00:00:00 2001 From: bracesproul Date: Wed, 12 Jun 2024 11:49:14 -0700 Subject: [PATCH 11/11] conditionally run standard tests too and make oai change to trigger --- .github/workflows/standard-tests.yml | 24 +++++++++++++++++++ .github/workflows/unit-tests-integrations.yml | 1 + libs/langchain-openai/src/chat_models.ts | 7 +++--- 3 files changed, 28 insertions(+), 4 deletions(-) diff --git a/.github/workflows/standard-tests.yml b/.github/workflows/standard-tests.yml index d474706a7597..24bd8fb9b557 100644 --- a/.github/workflows/standard-tests.yml +++ b/.github/workflows/standard-tests.yml @@ -6,11 +6,29 @@ on: - cron: '0 13 * * *' 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 + standard-tests: runs-on: ubuntu-latest + needs: get-changed-files strategy: matrix: package: [anthropic, cohere, google-genai, groq, mistralai] + if: contains(needs.get-changed-files.outputs.changed_files, 'langchain-core/') || contains(needs.get-changed-files.outputs.changed_files, 'libs/langchain-${{ matrix.package }}/') steps: - uses: actions/checkout@v4 - name: Use Node.js 18.x @@ -34,6 +52,8 @@ jobs: # we need separate jobs for each test. standard-tests-openai: runs-on: ubuntu-latest + 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 18.x @@ -52,6 +72,8 @@ jobs: standard-tests-azure-openai: runs-on: ubuntu-latest + 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 18.x @@ -73,6 +95,8 @@ jobs: standard-tests-bedrock: runs-on: ubuntu-latest + 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-community/') steps: - uses: actions/checkout@v4 - name: Use Node.js 18.x diff --git a/.github/workflows/unit-tests-integrations.yml b/.github/workflows/unit-tests-integrations.yml index 03aed75005a6..06af6388b01e 100644 --- a/.github/workflows/unit-tests-integrations.yml +++ b/.github/workflows/unit-tests-integrations.yml @@ -43,6 +43,7 @@ jobs: unit-tests: name: Unit Tests + needs: get-changed-files strategy: matrix: os: [ubuntu-latest] diff --git a/libs/langchain-openai/src/chat_models.ts b/libs/langchain-openai/src/chat_models.ts index a6477039114c..243518c41c2d 100644 --- a/libs/langchain-openai/src/chat_models.ts +++ b/libs/langchain-openai/src/chat_models.ts @@ -274,14 +274,13 @@ export interface ChatOpenAICallOptions /** * Wrapper around OpenAI large language models that use the Chat endpoint. * - * To use you should have the `openai` package installed, with the - * `OPENAI_API_KEY` environment variable set. + * To use you should have the `OPENAI_API_KEY` environment variable set. * - * To use with Azure you should have the `openai` package installed, with the + * To use with Azure you should have the: * `AZURE_OPENAI_API_KEY`, * `AZURE_OPENAI_API_INSTANCE_NAME`, * `AZURE_OPENAI_API_DEPLOYMENT_NAME` - * and `AZURE_OPENAI_API_VERSION` environment variable set. + * and `AZURE_OPENAI_API_VERSION` environment variables set. * `AZURE_OPENAI_BASE_PATH` is optional and will override `AZURE_OPENAI_API_INSTANCE_NAME` if you need to use a custom endpoint. * * @remarks