2023-09-13 23:23:49 +00:00
|
|
|
"""Test Baidu Qianfan Embedding Endpoint."""
|
2023-12-11 21:53:30 +00:00
|
|
|
from langchain_community.embeddings.baidu_qianfan_endpoint import (
|
|
|
|
QianfanEmbeddingsEndpoint,
|
|
|
|
)
|
2023-09-13 23:23:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_embedding_multiple_documents() -> None:
|
|
|
|
documents = ["foo", "bar"]
|
|
|
|
embedding = QianfanEmbeddingsEndpoint()
|
|
|
|
output = embedding.embed_documents(documents)
|
|
|
|
assert len(output) == 2
|
|
|
|
assert len(output[0]) == 384
|
|
|
|
assert len(output[1]) == 384
|
|
|
|
|
|
|
|
|
|
|
|
def test_embedding_query() -> None:
|
|
|
|
query = "foo"
|
|
|
|
embedding = QianfanEmbeddingsEndpoint()
|
|
|
|
output = embedding.embed_query(query)
|
|
|
|
assert len(output) == 384
|
|
|
|
|
|
|
|
|
|
|
|
def test_model() -> None:
|
|
|
|
documents = ["hi", "qianfan"]
|
|
|
|
embedding = QianfanEmbeddingsEndpoint(model="Embedding-V1")
|
|
|
|
output = embedding.embed_documents(documents)
|
|
|
|
assert len(output) == 2
|
2024-01-01 21:12:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_rate_limit() -> None:
|
|
|
|
llm = QianfanEmbeddingsEndpoint(
|
|
|
|
model="Embedding-V1", init_kwargs={"query_per_second": 2}
|
|
|
|
)
|
|
|
|
assert llm.client._client._rate_limiter._sync_limiter._query_per_second == 2
|
|
|
|
documents = ["foo", "bar"]
|
|
|
|
output = llm.embed_documents(documents)
|
|
|
|
assert len(output) == 2
|
|
|
|
assert len(output[0]) == 384
|
|
|
|
assert len(output[1]) == 384
|