2023-12-06 19:43:03 +00:00
|
|
|
---
|
2024-02-01 19:09:37 +00:00
|
|
|
name: CI
|
2023-12-06 19:43:03 +00:00
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches: [master]
|
|
|
|
pull_request:
|
|
|
|
|
|
|
|
# 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
|
|
|
|
|
2024-02-23 00:53:10 +00:00
|
|
|
env:
|
|
|
|
POETRY_VERSION: "1.7.1"
|
|
|
|
|
2023-12-06 19:43:03 +00:00
|
|
|
jobs:
|
|
|
|
build:
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v4
|
2024-01-01 22:02:43 +00:00
|
|
|
- uses: actions/setup-python@v5
|
2023-12-06 19:43:03 +00:00
|
|
|
with:
|
2024-06-17 20:50:31 +00:00
|
|
|
python-version: '3.11'
|
2023-12-06 19:43:03 +00:00
|
|
|
- id: files
|
|
|
|
uses: Ana06/get-changed-files@v2.2.0
|
|
|
|
- id: set-matrix
|
2024-01-03 21:30:16 +00:00
|
|
|
run: |
|
|
|
|
python .github/scripts/check_diff.py ${{ steps.files.outputs.all }} >> $GITHUB_OUTPUT
|
2023-12-06 19:43:03 +00:00
|
|
|
outputs:
|
2024-02-24 00:39:08 +00:00
|
|
|
dirs-to-lint: ${{ steps.set-matrix.outputs.dirs-to-lint }}
|
|
|
|
dirs-to-test: ${{ steps.set-matrix.outputs.dirs-to-test }}
|
|
|
|
dirs-to-extended-test: ${{ steps.set-matrix.outputs.dirs-to-extended-test }}
|
2024-04-18 23:42:03 +00:00
|
|
|
docs-edited: ${{ steps.set-matrix.outputs.docs-edited }}
|
2024-02-23 00:53:10 +00:00
|
|
|
lint:
|
|
|
|
name: cd ${{ matrix.working-directory }}
|
|
|
|
needs: [ build ]
|
2024-02-24 00:39:08 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-lint != '[]' }}
|
2024-02-23 00:53:10 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-02-24 00:39:08 +00:00
|
|
|
working-directory: ${{ fromJson(needs.build.outputs.dirs-to-lint) }}
|
2024-02-23 00:53:10 +00:00
|
|
|
uses: ./.github/workflows/_lint.yml
|
|
|
|
with:
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
|
|
|
secrets: inherit
|
|
|
|
|
|
|
|
test:
|
2024-02-01 19:09:37 +00:00
|
|
|
name: cd ${{ matrix.working-directory }}
|
2023-12-06 19:43:03 +00:00
|
|
|
needs: [ build ]
|
2024-02-24 00:39:08 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-test != '[]' }}
|
2023-12-06 19:43:03 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-02-24 00:39:08 +00:00
|
|
|
working-directory: ${{ fromJson(needs.build.outputs.dirs-to-test) }}
|
2024-02-23 00:53:10 +00:00
|
|
|
uses: ./.github/workflows/_test.yml
|
2023-12-06 19:43:03 +00:00
|
|
|
with:
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
2024-02-23 00:53:10 +00:00
|
|
|
secrets: inherit
|
|
|
|
|
2024-04-19 02:06:57 +00:00
|
|
|
test-doc-imports:
|
2024-03-29 17:30:20 +00:00
|
|
|
needs: [ build ]
|
2024-04-18 23:42:03 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-test != '[]' || needs.build.outputs.docs-edited }}
|
2024-03-29 17:30:20 +00:00
|
|
|
uses: ./.github/workflows/_test_doc_imports.yml
|
|
|
|
secrets: inherit
|
|
|
|
|
2024-02-23 00:53:10 +00:00
|
|
|
compile-integration-tests:
|
|
|
|
name: cd ${{ matrix.working-directory }}
|
|
|
|
needs: [ build ]
|
2024-02-24 00:39:08 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-test != '[]' }}
|
2024-02-23 00:53:10 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-02-24 00:39:08 +00:00
|
|
|
working-directory: ${{ fromJson(needs.build.outputs.dirs-to-test) }}
|
2024-02-23 00:53:10 +00:00
|
|
|
uses: ./.github/workflows/_compile_integration_test.yml
|
|
|
|
with:
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
|
|
|
secrets: inherit
|
|
|
|
|
|
|
|
dependencies:
|
|
|
|
name: cd ${{ matrix.working-directory }}
|
|
|
|
needs: [ build ]
|
2024-02-24 00:39:08 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-test != '[]' }}
|
2024-02-23 00:53:10 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
2024-02-24 00:39:08 +00:00
|
|
|
working-directory: ${{ fromJson(needs.build.outputs.dirs-to-test) }}
|
2024-02-23 00:53:10 +00:00
|
|
|
uses: ./.github/workflows/_dependencies.yml
|
|
|
|
with:
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
|
|
|
secrets: inherit
|
|
|
|
|
|
|
|
extended-tests:
|
|
|
|
name: "cd ${{ matrix.working-directory }} / make extended_tests #${{ matrix.python-version }}"
|
|
|
|
needs: [ build ]
|
2024-02-24 00:39:08 +00:00
|
|
|
if: ${{ needs.build.outputs.dirs-to-extended-test != '[]' }}
|
2024-02-23 00:53:10 +00:00
|
|
|
strategy:
|
|
|
|
matrix:
|
|
|
|
# note different variable for extended test dirs
|
2024-02-24 00:39:08 +00:00
|
|
|
working-directory: ${{ fromJson(needs.build.outputs.dirs-to-extended-test) }}
|
2024-02-23 00:53:10 +00:00
|
|
|
python-version:
|
|
|
|
- "3.8"
|
|
|
|
- "3.9"
|
|
|
|
- "3.10"
|
|
|
|
- "3.11"
|
2024-06-18 17:15:04 +00:00
|
|
|
- "3.12.3"
|
2024-02-23 00:53:10 +00:00
|
|
|
runs-on: ubuntu-latest
|
|
|
|
defaults:
|
|
|
|
run:
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
|
|
|
steps:
|
|
|
|
- uses: actions/checkout@v4
|
|
|
|
|
|
|
|
- name: Set up Python ${{ matrix.python-version }} + Poetry ${{ env.POETRY_VERSION }}
|
|
|
|
uses: "./.github/actions/poetry_setup"
|
|
|
|
with:
|
|
|
|
python-version: ${{ matrix.python-version }}
|
|
|
|
poetry-version: ${{ env.POETRY_VERSION }}
|
|
|
|
working-directory: ${{ matrix.working-directory }}
|
|
|
|
cache-key: extended
|
|
|
|
|
|
|
|
- name: Install dependencies
|
|
|
|
shell: bash
|
|
|
|
run: |
|
|
|
|
echo "Running extended tests, installing dependencies with poetry..."
|
2024-06-06 22:45:22 +00:00
|
|
|
poetry install --with test
|
|
|
|
poetry run pip install uv
|
|
|
|
poetry run uv pip install -r extended_testing_deps.txt
|
2024-02-23 00:53:10 +00:00
|
|
|
|
|
|
|
- name: Run extended tests
|
|
|
|
run: make extended_tests
|
|
|
|
|
|
|
|
- name: Ensure the tests did not create any additional files
|
|
|
|
shell: bash
|
|
|
|
run: |
|
|
|
|
set -eu
|
|
|
|
|
|
|
|
STATUS="$(git status)"
|
|
|
|
echo "$STATUS"
|
|
|
|
|
|
|
|
# grep will exit non-zero if the target message isn't found,
|
|
|
|
# and `set -e` above will cause the step to fail.
|
|
|
|
echo "$STATUS" | grep 'nothing to commit, working tree clean'
|
2024-02-23 01:22:35 +00:00
|
|
|
ci_success:
|
2024-02-23 00:53:10 +00:00
|
|
|
name: "CI Success"
|
2024-04-19 02:06:57 +00:00
|
|
|
needs: [build, lint, test, compile-integration-tests, dependencies, extended-tests, test-doc-imports]
|
infra: CI success for partner packages (#18037)
Thank you for contributing to LangChain!
- [ ] **PR title**: "package: description"
- Where "package" is whichever of langchain, community, core,
experimental, etc. is being modified. Use "docs: ..." for purely docs
changes, "templates: ..." for template changes, "infra: ..." for CI
changes.
- Example: "community: add foobar LLM"
- [ ] **PR message**: ***Delete this entire checklist*** and replace
with
- **Description:** a description of the change
- **Issue:** the issue # it fixes, if applicable
- **Dependencies:** any dependencies required for this change
- **Twitter handle:** if your PR gets announced, and you'd like a
mention, we'll gladly shout you out!
- [ ] **Add tests and docs**: If you're adding a new integration, please
include
1. a test for the integration, preferably unit tests that do not rely on
network access,
2. an example notebook showing its use. It lives in
`docs/docs/integrations` directory.
- [ ] **Lint and test**: Run `make format`, `make lint` and `make test`
from the root of the package(s) you've modified. See contribution
guidelines for more: https://python.langchain.com/docs/contributing/
Additional guidelines:
- Make sure optional dependencies are imported within a function.
- Please do not add dependencies to pyproject.toml files (even optional
ones) unless they are required for unit tests.
- Most PRs should not touch more than one package.
- Changes should be backwards compatible.
- If you are adding something to community, do not re-import it in
langchain.
If no one reviews your PR within a few days, please @-mention one of
baskaryan, efriis, eyurtsev, hwchase17.
2024-02-23 19:00:48 +00:00
|
|
|
if: |
|
|
|
|
always()
|
2024-02-23 00:53:10 +00:00
|
|
|
runs-on: ubuntu-latest
|
infra: CI success for partner packages (#18037)
Thank you for contributing to LangChain!
- [ ] **PR title**: "package: description"
- Where "package" is whichever of langchain, community, core,
experimental, etc. is being modified. Use "docs: ..." for purely docs
changes, "templates: ..." for template changes, "infra: ..." for CI
changes.
- Example: "community: add foobar LLM"
- [ ] **PR message**: ***Delete this entire checklist*** and replace
with
- **Description:** a description of the change
- **Issue:** the issue # it fixes, if applicable
- **Dependencies:** any dependencies required for this change
- **Twitter handle:** if your PR gets announced, and you'd like a
mention, we'll gladly shout you out!
- [ ] **Add tests and docs**: If you're adding a new integration, please
include
1. a test for the integration, preferably unit tests that do not rely on
network access,
2. an example notebook showing its use. It lives in
`docs/docs/integrations` directory.
- [ ] **Lint and test**: Run `make format`, `make lint` and `make test`
from the root of the package(s) you've modified. See contribution
guidelines for more: https://python.langchain.com/docs/contributing/
Additional guidelines:
- Make sure optional dependencies are imported within a function.
- Please do not add dependencies to pyproject.toml files (even optional
ones) unless they are required for unit tests.
- Most PRs should not touch more than one package.
- Changes should be backwards compatible.
- If you are adding something to community, do not re-import it in
langchain.
If no one reviews your PR within a few days, please @-mention one of
baskaryan, efriis, eyurtsev, hwchase17.
2024-02-23 19:00:48 +00:00
|
|
|
env:
|
|
|
|
JOBS_JSON: ${{ toJSON(needs) }}
|
|
|
|
RESULTS_JSON: ${{ toJSON(needs.*.result) }}
|
|
|
|
EXIT_CODE: ${{!contains(needs.*.result, 'failure') && !contains(needs.*.result, 'cancelled') && '0' || '1'}}
|
2024-02-23 00:53:10 +00:00
|
|
|
steps:
|
|
|
|
- name: "CI Success"
|
|
|
|
run: |
|
infra: CI success for partner packages (#18037)
Thank you for contributing to LangChain!
- [ ] **PR title**: "package: description"
- Where "package" is whichever of langchain, community, core,
experimental, etc. is being modified. Use "docs: ..." for purely docs
changes, "templates: ..." for template changes, "infra: ..." for CI
changes.
- Example: "community: add foobar LLM"
- [ ] **PR message**: ***Delete this entire checklist*** and replace
with
- **Description:** a description of the change
- **Issue:** the issue # it fixes, if applicable
- **Dependencies:** any dependencies required for this change
- **Twitter handle:** if your PR gets announced, and you'd like a
mention, we'll gladly shout you out!
- [ ] **Add tests and docs**: If you're adding a new integration, please
include
1. a test for the integration, preferably unit tests that do not rely on
network access,
2. an example notebook showing its use. It lives in
`docs/docs/integrations` directory.
- [ ] **Lint and test**: Run `make format`, `make lint` and `make test`
from the root of the package(s) you've modified. See contribution
guidelines for more: https://python.langchain.com/docs/contributing/
Additional guidelines:
- Make sure optional dependencies are imported within a function.
- Please do not add dependencies to pyproject.toml files (even optional
ones) unless they are required for unit tests.
- Most PRs should not touch more than one package.
- Changes should be backwards compatible.
- If you are adding something to community, do not re-import it in
langchain.
If no one reviews your PR within a few days, please @-mention one of
baskaryan, efriis, eyurtsev, hwchase17.
2024-02-23 19:00:48 +00:00
|
|
|
echo $JOBS_JSON
|
|
|
|
echo $RESULTS_JSON
|
|
|
|
echo "Exiting with $EXIT_CODE"
|
|
|
|
exit $EXIT_CODE
|