fake.py — langchain Source File
Architecture documentation for fake.py, a python file in the langchain codebase. 9 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 1ff71dfa_a51d_6036_ad93_e1783176f476["fake.py"] a327e534_84f6_5308_58ca_5727d5eda0cf["asyncio"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> a327e534_84f6_5308_58ca_5727d5eda0cf 0c1d9a1b_c553_0388_dbc1_58af49567aa2["time"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> 0c1d9a1b_c553_0388_dbc1_58af49567aa2 cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7["collections.abc"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> cfe2bde5_180e_e3b0_df2b_55b3ebaca8e7 8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3["typing"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> 8e2034b7_ceb8_963f_29fc_2ea6b50ef9b3 91721f45_4909_e489_8c1f_084f8bd87145["typing_extensions"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> 91721f45_4909_e489_8c1f_084f8bd87145 f3bc7443_c889_119d_0744_aacc3620d8d2["langchain_core.callbacks"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> f3bc7443_c889_119d_0744_aacc3620d8d2 ba43b74d_3099_7e1c_aac3_cf594720469e["langchain_core.language_models"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> ba43b74d_3099_7e1c_aac3_cf594720469e 89934eed_a823_2184_acf2_039f48eed5f9["langchain_core.language_models.llms"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> 89934eed_a823_2184_acf2_039f48eed5f9 2ceb1686_0f8c_8ae0_36d1_7c0b702fda1c["langchain_core.runnables"] 1ff71dfa_a51d_6036_ad93_e1783176f476 --> 2ceb1686_0f8c_8ae0_36d1_7c0b702fda1c style 1ff71dfa_a51d_6036_ad93_e1783176f476 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
"""Fake LLMs for testing purposes."""
import asyncio
import time
from collections.abc import AsyncIterator, Iterator, Mapping
from typing import Any
from typing_extensions import override
from langchain_core.callbacks import (
AsyncCallbackManagerForLLMRun,
CallbackManagerForLLMRun,
)
from langchain_core.language_models import LanguageModelInput
from langchain_core.language_models.llms import LLM
from langchain_core.runnables import RunnableConfig
class FakeListLLM(LLM):
"""Fake LLM for testing purposes."""
responses: list[str]
"""List of responses to return in order."""
# This parameter should be removed from FakeListLLM since
# it's only used by sub-classes.
sleep: float | None = None
"""Sleep time in seconds between responses.
Ignored by FakeListLLM, but used by sub-classes.
"""
i: int = 0
"""Internally incremented after every model invocation.
Useful primarily for testing purposes.
"""
@property
@override
def _llm_type(self) -> str:
"""Return type of llm."""
return "fake-list"
@override
def _call(
self,
prompt: str,
stop: list[str] | None = None,
run_manager: CallbackManagerForLLMRun | None = None,
**kwargs: Any,
) -> str:
"""Return next response."""
response = self.responses[self.i]
if self.i < len(self.responses) - 1:
self.i += 1
else:
self.i = 0
return response
@override
async def _acall(
// ... (78 more lines)
Domain
Subdomains
Dependencies
- asyncio
- collections.abc
- langchain_core.callbacks
- langchain_core.language_models
- langchain_core.language_models.llms
- langchain_core.runnables
- time
- typing
- typing_extensions
Source
Frequently Asked Questions
What does fake.py do?
fake.py is a source file in the langchain codebase, written in python. It belongs to the CoreAbstractions domain, Serialization subdomain.
What does fake.py depend on?
fake.py imports 9 module(s): asyncio, collections.abc, langchain_core.callbacks, langchain_core.language_models, langchain_core.language_models.llms, langchain_core.runnables, time, typing, and 1 more.
Where is fake.py in the architecture?
fake.py is located at libs/core/langchain_core/language_models/fake.py (domain: CoreAbstractions, subdomain: Serialization, directory: libs/core/langchain_core/language_models).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free