renesis / libs /kotaemon /tests /test_reranking.py
noumanjavaid's picture
Upload folder using huggingface_hub
ad33df7 verified
raw
history blame
1.75 kB
from unittest.mock import patch
import pytest
from openai.types.chat.chat_completion import ChatCompletion
from kotaemon.base import Document
from kotaemon.indices.rankings import LLMReranking
from kotaemon.llms import AzureChatOpenAI
_openai_chat_completion_responses = [
ChatCompletion.parse_obj(
{
"id": "chatcmpl-7qyuw6Q1CFCpcKsMdFkmUPUa7JP2x",
"object": "chat.completion",
"created": 1692338378,
"model": "gpt-35-turbo",
"system_fingerprint": None,
"choices": [
{
"index": 0,
"finish_reason": "stop",
"message": {
"role": "assistant",
"content": text,
"function_call": None,
"tool_calls": None,
},
"logprobs": None,
}
],
"usage": {"completion_tokens": 9, "prompt_tokens": 10, "total_tokens": 19},
}
)
for text in [
"YES",
"NO",
"YES",
]
]
@pytest.fixture
def llm():
return AzureChatOpenAI(
api_key="dummy",
api_version="2024-05-01-preview",
azure_deployment="gpt-4o",
azure_endpoint="https://test.openai.azure.com/",
)
@patch(
"openai.resources.chat.completions.Completions.create",
side_effect=_openai_chat_completion_responses,
)
def test_reranking(openai_completion, llm):
documents = [Document(text=f"test {idx}") for idx in range(3)]
query = "test query"
reranker = LLMReranking(llm=llm, concurrent=False)
rerank_docs = reranker(documents, query=query)
assert len(rerank_docs) == 2