Home / File/ test_langchain.py — langchain Source File

test_langchain.py — langchain Source File

Architecture documentation for test_langchain.py, a python file in the langchain codebase. 12 imports, 0 dependents.

File python LangChainCore ApiManagement 12 imports 14 functions

Entity Profile

Dependency Diagram

graph LR
  6ee6ed10_3ff3_3d50_08bc_311ea99250db["test_langchain.py"]
  115d9bf0_a63e_564c_f8d8_eb2c82bbd856["threading"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 115d9bf0_a63e_564c_f8d8_eb2c82bbd856
  996b2db9_46dd_901f_f7eb_068bafab4b12["time"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 996b2db9_46dd_901f_f7eb_068bafab4b12
  23cb242e_1754_041d_200a_553fcb8abe1b["unittest.mock"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 23cb242e_1754_041d_200a_553fcb8abe1b
  02f66451_d2a9_e7c3_9765_c3a7594721ad["uuid"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 02f66451_d2a9_e7c3_9765_c3a7594721ad
  feec1ec4_6917_867b_d228_b134d0ff8099["typing"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> feec1ec4_6917_867b_d228_b134d0ff8099
  f69d6389_263d_68a4_7fbf_f14c0602a9ba["pytest"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> f69d6389_263d_68a4_7fbf_f14c0602a9ba
  b8aff3f8_6287_d5fe_af3e_1ecda79d9656["langsmith"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> b8aff3f8_6287_d5fe_af3e_1ecda79d9656
  2d50b612_c628_e1c5_9e13_3ef01f00dbe1["langsmith.run_trees"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 2d50b612_c628_e1c5_9e13_3ef01f00dbe1
  a7164c1d_6465_934a_12bb_0b7b6654055a["langsmith.utils"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> a7164c1d_6465_934a_12bb_0b7b6654055a
  4382dc25_6fba_324a_49e2_e9742d579385["langchain_core.outputs"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 4382dc25_6fba_324a_49e2_e9742d579385
  846ca6e3_1658_c38e_f506_8418b4c3f527["langchain_core.tracers.langchain"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 846ca6e3_1658_c38e_f506_8418b4c3f527
  36cb50e1_bcef_f6a3_9561_cc46faff8973["langchain_core.tracers.schemas"]
  6ee6ed10_3ff3_3d50_08bc_311ea99250db --> 36cb50e1_bcef_f6a3_9561_cc46faff8973
  style 6ee6ed10_3ff3_3d50_08bc_311ea99250db fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import threading
import time
import unittest.mock
import uuid
from typing import Any
from uuid import UUID

import pytest
from langsmith import Client
from langsmith.run_trees import RunTree
from langsmith.utils import get_env_var, get_tracer_project

from langchain_core.outputs import LLMResult
from langchain_core.tracers.langchain import (
    LangChainTracer,
    _get_usage_metadata_from_generations,
)
from langchain_core.tracers.schemas import Run


def test_example_id_assignment_threadsafe() -> None:
    """Test that example assigned at callback start/end is honored."""
    example_ids = {}

    def mock_create_run(**kwargs: Any) -> Any:
        example_ids[kwargs.get("id")] = kwargs.get("reference_example_id")
        return unittest.mock.MagicMock()

    client = unittest.mock.MagicMock(spec=Client)
    client.tracing_queue = None
    client.create_run = mock_create_run
    tracer = LangChainTracer(client=client)
    old_persist_run_single = tracer._persist_run_single

    def new_persist_run_single(run: Run) -> None:
        time.sleep(0.01)
        old_persist_run_single(run)

    with unittest.mock.patch.object(
        tracer, "_persist_run_single", new=new_persist_run_single
    ):
        run_id_1 = UUID("9d878ab3-e5ca-4218-aef6-44cbdc90160a")
        run_id_2 = UUID("f1f9fa53-8b2f-4742-bdbc-38215f7bd1e1")
        run_id_3 = UUID("f1f9fa53-8b2f-4742-bdbc-38215f7cd1e1")
        example_id_1 = UUID("57e42c57-8c79-4d9f-8765-bf6cd3a98055")
        tracer.example_id = example_id_1
        tracer.on_llm_start({"name": "example_1"}, ["foo"], run_id=run_id_1)
        tracer.on_llm_end(LLMResult(generations=[], llm_output={}), run_id=run_id_1)
        example_id_2 = UUID("4f31216e-7c26-4027-a5fd-0bbf9ace17dc")
        tracer.example_id = example_id_2
        tracer.on_llm_start({"name": "example_2"}, ["foo"], run_id=run_id_2)
        tracer.on_llm_end(LLMResult(generations=[], llm_output={}), run_id=run_id_2)
        tracer.example_id = None
        tracer.on_chain_start(
            {"name": "no_examples"}, {"inputs": (i for i in range(10))}, run_id=run_id_3
        )
        tracer.on_chain_error(ValueError("Foo bar"), run_id=run_id_3)
        expected_example_ids = {
            run_id_1: example_id_1,
            run_id_2: example_id_2,
// ... (511 more lines)

Domain

Subdomains

Dependencies

  • langchain_core.outputs
  • langchain_core.tracers.langchain
  • langchain_core.tracers.schemas
  • langsmith
  • langsmith.run_trees
  • langsmith.utils
  • pytest
  • threading
  • time
  • typing
  • unittest.mock
  • uuid

Frequently Asked Questions

What does test_langchain.py do?
test_langchain.py is a source file in the langchain codebase, written in python. It belongs to the LangChainCore domain, ApiManagement subdomain.
What functions are defined in test_langchain.py?
test_langchain.py defines 14 function(s): test_correct_get_tracer_project, test_example_id_assignment_threadsafe, test_get_usage_metadata_from_generations, test_log_lock, test_on_chain_end_persists_when_defers_inputs, test_on_chain_end_updates_when_not_defers_inputs, test_on_chain_error_persists_when_defers_inputs, test_on_chain_error_updates_when_not_defers_inputs, test_on_chain_start_persists_when_not_defers_inputs, test_on_chain_start_skips_persist_when_defers_inputs, and 4 more.
What does test_langchain.py depend on?
test_langchain.py imports 12 module(s): langchain_core.outputs, langchain_core.tracers.langchain, langchain_core.tracers.schemas, langsmith, langsmith.run_trees, langsmith.utils, pytest, threading, and 4 more.
Where is test_langchain.py in the architecture?
test_langchain.py is located at libs/core/tests/unit_tests/tracers/test_langchain.py (domain: LangChainCore, subdomain: ApiManagement, directory: libs/core/tests/unit_tests/tracers).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free