2023-03-28 18:56:57 +00:00
|
|
|
"""Test Replicate API wrapper."""
|
|
|
|
|
2023-12-11 21:53:30 +00:00
|
|
|
from langchain_core.callbacks import CallbackManager
|
|
|
|
|
|
|
|
from langchain_community.llms.replicate import Replicate
|
2023-07-21 01:59:54 +00:00
|
|
|
from tests.unit_tests.callbacks.fake_callback_handler import FakeCallbackHandler
|
|
|
|
|
2023-09-14 21:02:01 +00:00
|
|
|
TEST_MODEL = "replicate/dolly-v2-12b:ef0e1aefc61f8e096ebe4db6b2bacc297daf2ef6899f0f7e001ec445893500e5" # noqa: E501
|
2023-03-28 18:56:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_replicate_call() -> None:
|
2023-07-21 01:59:54 +00:00
|
|
|
"""Test simple non-streaming call to Replicate."""
|
|
|
|
llm = Replicate(model=TEST_MODEL)
|
2023-09-14 21:02:01 +00:00
|
|
|
output = llm("What is LangChain")
|
|
|
|
assert output
|
|
|
|
assert isinstance(output, str)
|
2023-07-21 01:59:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_replicate_streaming_call() -> None:
|
|
|
|
"""Test streaming call to Replicate."""
|
|
|
|
callback_handler = FakeCallbackHandler()
|
|
|
|
callback_manager = CallbackManager([callback_handler])
|
|
|
|
|
|
|
|
llm = Replicate(streaming=True, callback_manager=callback_manager, model=TEST_MODEL)
|
2023-09-14 21:02:01 +00:00
|
|
|
output = llm("What is LangChain")
|
|
|
|
assert output
|
|
|
|
assert isinstance(output, str)
|
2023-09-14 21:43:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_replicate_model_kwargs() -> None:
|
|
|
|
"""Test simple non-streaming call to Replicate."""
|
|
|
|
llm = Replicate(
|
|
|
|
model=TEST_MODEL, model_kwargs={"max_length": 100, "temperature": 0.01}
|
|
|
|
)
|
|
|
|
long_output = llm("What is LangChain")
|
|
|
|
llm = Replicate(
|
|
|
|
model=TEST_MODEL, model_kwargs={"max_length": 10, "temperature": 0.01}
|
|
|
|
)
|
|
|
|
short_output = llm("What is LangChain")
|
|
|
|
assert len(short_output) < len(long_output)
|
2023-09-14 22:04:42 +00:00
|
|
|
assert llm.model_kwargs == {"max_length": 10, "temperature": 0.01}
|
2023-09-14 21:43:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_replicate_input() -> None:
|
|
|
|
llm = Replicate(model=TEST_MODEL, input={"max_length": 10})
|
|
|
|
assert llm.model_kwargs == {"max_length": 10}
|