Skip to content

Commit

Permalink
test: trying to deal with CI problem
Browse files Browse the repository at this point in the history
  • Loading branch information
yanomaly committed Nov 14, 2024
1 parent c5f759c commit f2a16b9
Show file tree
Hide file tree
Showing 2 changed files with 136 additions and 91 deletions.
197 changes: 114 additions & 83 deletions libs/community/tests/unit_tests/chat_models/test_writer.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,117 +13,148 @@
from langchain_community.chat_models.writer import ChatWriter
from tests.unit_tests.callbacks.fake_callback_handler import FakeCallbackHandler

"""Classes for mocking Writer responses."""

@pytest.mark.requires("writerai")

class ChoiceDelta:
def __init__(self, content: str):
self.content = content


class ChunkChoice:
def __init__(self, index: int, finish_reason: str, delta: ChoiceDelta):
self.index = index
self.finish_reason = finish_reason
self.delta = delta


class ChatCompletionChunk:
def __init__(
self,
id: str,
object: str,
created: int,
model: str,
choices: List[ChunkChoice],
):
self.id = id
self.object = object
self.created = created
self.model = model
self.choices = choices


class ToolCallFunction:
def __init__(self, name: str, arguments: str):
self.name = name
self.arguments = arguments


class ChoiceMessageToolCall:
def __init__(self, id: str, type: str, function: ToolCallFunction):
self.id = id
self.type = type
self.function = function


class Usage:
def __init__(
self,
prompt_tokens: int,
completion_tokens: int,
total_tokens: int,
):
self.prompt_tokens = prompt_tokens
self.completion_tokens = completion_tokens
self.total_tokens = total_tokens


class ChoiceMessage:
def __init__(
self,
role: str,
content: str,
tool_calls: Optional[List[ChoiceMessageToolCall]] = None,
):
self.role = role
self.content = content
self.tool_calls = tool_calls


class Choice:
def __init__(self, index: int, finish_reason: str, message: ChoiceMessage):
self.index = index
self.finish_reason = finish_reason
self.message = message


class Chat:
def __init__(
self,
id: str,
object: str,
created: int,
system_fingerprint: str,
model: str,
usage: Usage,
choices: List[Choice],
):
self.id = id
self.object = object
self.created = created
self.system_fingerprint = system_fingerprint
self.model = model
self.usage = usage
self.choices = choices


@pytest.mark.requires("writer-sdk")
class TestChatWriterCustom:
"""Test case for ChatWriter"""

from writerai.types import Chat
from writerai.types.chat import (
Choice,
ChoiceLogprobs,
ChoiceLogprobsContent,
ChoiceLogprobsContentTopLogprob,
ChoiceLogprobsRefusal,
ChoiceLogprobsRefusalTopLogprob,
ChoiceMessage,
ChoiceMessageToolCall,
ChoiceMessageToolCallFunction,
Usage,
)
from writerai.types.chat_completion_chunk import ChatCompletionChunk, ChoiceDelta
from writerai.types.chat_completion_chunk import Choice as ChunkChoice

@pytest.fixture(autouse=True)
def mock_unstreaming_completion(self) -> Chat:
"""Fixture providing a mock API response."""
return self.Chat(
return Chat(
id="chat-12345",
object="chat.completion",
created=1699000000,
model="palmyra-x-004",
usage=self.Usage(prompt_tokens=10, completion_tokens=8, total_tokens=18),
system_fingerprint="v1",
usage=Usage(prompt_tokens=10, completion_tokens=8, total_tokens=18),
choices=[
self.Choice(
Choice(
index=0,
finish_reason="stop",
logprobs=self.ChoiceLogprobs(
content=[
self.ChoiceLogprobsContent(
token="",
logprob=0,
top_logprobs=[
self.ChoiceLogprobsContentTopLogprob(
token="", logprob=0
)
],
)
],
refusal=[
self.ChoiceLogprobsRefusal(
token="",
logprob=0,
top_logprobs=[
self.ChoiceLogprobsRefusalTopLogprob(
token="", logprob=0
)
],
)
],
),
message=self.ChoiceMessage(
message=ChoiceMessage(
role="assistant",
content="Hello! How can I help you?",
refusal="",
),
)
],
)

@pytest.fixture(autouse=True)
def mock_tool_call_choice_response(self) -> Chat:
return self.Chat(
return Chat(
id="chat-12345",
object="chat.completion",
created=1699000000,
model="palmyra-x-004",
system_fingerprint="v1",
usage=Usage(prompt_tokens=29, completion_tokens=32, total_tokens=61),
choices=[
self.Choice(
Choice(
index=0,
finish_reason="tool_calls",
logprobs=self.ChoiceLogprobs(
content=[
self.ChoiceLogprobsContent(
token="",
logprob=0,
top_logprobs=[
self.ChoiceLogprobsContentTopLogprob(
token="", logprob=0
)
],
)
],
refusal=[
self.ChoiceLogprobsRefusal(
token="",
logprob=0,
top_logprobs=[
self.ChoiceLogprobsRefusalTopLogprob(
token="", logprob=0
)
],
)
],
),
message=self.ChoiceMessage(
message=ChoiceMessage(
role="assistant",
content="",
refusal="",
tool_calls=[
self.ChoiceMessageToolCall(
ChoiceMessageToolCall(
id="call_abc123",
type="function",
function=self.ChoiceMessageToolCallFunction(
function=ToolCallFunction(
name="GetWeather",
arguments='{"location": "London"}',
),
Expand All @@ -138,29 +169,29 @@ def mock_tool_call_choice_response(self) -> Chat:
def mock_streaming_chunks(self) -> List[ChatCompletionChunk]:
"""Fixture providing mock streaming response chunks."""
return [
self.ChatCompletionChunk(
ChatCompletionChunk(
id="chat-12345",
object="chat.completion",
created=1699000000,
model="palmyra-x-004",
choices=[
self.ChunkChoice(
ChunkChoice(
index=0,
finish_reason="stop",
delta=self.ChoiceDelta(content="Hello! "),
delta=ChoiceDelta(content="Hello! "),
)
],
),
self.ChatCompletionChunk(
ChatCompletionChunk(
id="chat-12345",
object="chat.completion",
created=1699000000,
model="palmyra-x-004",
choices=[
self.ChunkChoice(
ChunkChoice(
index=0,
finish_reason="stop",
delta=self.ChoiceDelta(content="How can I help you?"),
delta=ChoiceDelta(content="How can I help you?"),
)
],
),
Expand Down Expand Up @@ -395,7 +426,7 @@ class GetWeather(BaseModel):
assert response.tool_calls[0]["args"]["location"] == "London"


@pytest.mark.requires("writerai")
@pytest.mark.requires("writer-sdk")
class TestChatWriterStandart(ChatModelUnitTests):
"""Test case for ChatWriter that inherits from standard LangChain tests."""

Expand Down
30 changes: 22 additions & 8 deletions libs/community/tests/unit_tests/llms/test_writer.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,26 +9,40 @@
from langchain_community.llms.writer import Writer
from tests.unit_tests.callbacks.fake_callback_handler import FakeCallbackHandler

"""Classes for mocking Writer responses."""

@pytest.mark.requires("writerai")

class Choice:
def __init__(self, text: str):
self.text = text


class Completion:
def __init__(self, choices: List[Choice]):
self.choices = choices


class StreamingData:
def __init__(self, value: str):
self.value = value


@pytest.mark.requires("writer-sdk")
class TestWriterLLM:
"""Unit tests for Writer LLM integration."""

from writerai.types import Completion, StreamingData
from writerai.types.completion import Choice

@pytest.fixture(autouse=True)
def mock_unstreaming_completion(self) -> Completion:
"""Fixture providing a mock API response."""
return self.Completion(choices=[self.Choice(text="Hello! How can I help you?")])
return Completion(choices=[Choice(text="Hello! How can I help you?")])

@pytest.fixture(autouse=True)
def mock_streaming_completion(self) -> List[StreamingData]:
"""Fixture providing mock streaming response chunks."""
return [
self.StreamingData(value="Hello! "),
self.StreamingData(value="How can I"),
self.StreamingData(value=" help you?"),
StreamingData(value="Hello! "),
StreamingData(value="How can I"),
StreamingData(value=" help you?"),
]

def test_sync_unstream_completion(
Expand Down

0 comments on commit f2a16b9

Please sign in to comment.