Improve and add more tests (#807)
This commit is contained in:
@@ -1,33 +1,55 @@
|
||||
import os
|
||||
import unittest
|
||||
from unittest.mock import patch
|
||||
import pytest
|
||||
|
||||
from embedchain.config import BaseLlmConfig
|
||||
from embedchain.llm.cohere import CohereLlm
|
||||
|
||||
|
||||
class TestCohereLlm(unittest.TestCase):
|
||||
def setUp(self):
|
||||
os.environ["COHERE_API_KEY"] = "test_api_key"
|
||||
self.config = BaseLlmConfig(model="gptd-instruct-tft", max_tokens=50, temperature=0.7, top_p=0.8)
|
||||
@pytest.fixture
|
||||
def cohere_llm_config():
|
||||
os.environ["COHERE_API_KEY"] = "test_api_key"
|
||||
config = BaseLlmConfig(model="gptd-instruct-tft", max_tokens=50, temperature=0.7, top_p=0.8)
|
||||
yield config
|
||||
os.environ.pop("COHERE_API_KEY")
|
||||
|
||||
def test_init_raises_value_error_without_api_key(self):
|
||||
os.environ.pop("COHERE_API_KEY")
|
||||
with self.assertRaises(ValueError):
|
||||
CohereLlm()
|
||||
|
||||
def test_get_llm_model_answer_raises_value_error_for_system_prompt(self):
|
||||
llm = CohereLlm(self.config)
|
||||
llm.config.system_prompt = "system_prompt"
|
||||
with self.assertRaises(ValueError):
|
||||
llm.get_llm_model_answer("prompt")
|
||||
def test_init_raises_value_error_without_api_key(mocker):
|
||||
mocker.patch.dict(os.environ, clear=True)
|
||||
with pytest.raises(ValueError):
|
||||
CohereLlm()
|
||||
|
||||
@patch("embedchain.llm.cohere.CohereLlm._get_answer")
|
||||
def test_get_llm_model_answer(self, mock_get_answer):
|
||||
mock_get_answer.return_value = "Test answer"
|
||||
|
||||
llm = CohereLlm(self.config)
|
||||
answer = llm.get_llm_model_answer("Test query")
|
||||
def test_get_llm_model_answer_raises_value_error_for_system_prompt(cohere_llm_config):
|
||||
llm = CohereLlm(cohere_llm_config)
|
||||
llm.config.system_prompt = "system_prompt"
|
||||
with pytest.raises(ValueError):
|
||||
llm.get_llm_model_answer("prompt")
|
||||
|
||||
self.assertEqual(answer, "Test answer")
|
||||
mock_get_answer.assert_called_once()
|
||||
|
||||
def test_get_llm_model_answer(cohere_llm_config, mocker):
|
||||
mocker.patch("embedchain.llm.cohere.CohereLlm._get_answer", return_value="Test answer")
|
||||
|
||||
llm = CohereLlm(cohere_llm_config)
|
||||
answer = llm.get_llm_model_answer("Test query")
|
||||
|
||||
assert answer == "Test answer"
|
||||
|
||||
|
||||
def test_get_answer_mocked_cohere(cohere_llm_config, mocker):
|
||||
mocked_cohere = mocker.patch("embedchain.llm.cohere.Cohere")
|
||||
mock_instance = mocked_cohere.return_value
|
||||
mock_instance.return_value = "Mocked answer"
|
||||
|
||||
llm = CohereLlm(cohere_llm_config)
|
||||
prompt = "Test query"
|
||||
answer = llm.get_llm_model_answer(prompt)
|
||||
|
||||
assert answer == "Mocked answer"
|
||||
mocked_cohere.assert_called_once_with(
|
||||
cohere_api_key="test_api_key",
|
||||
model="gptd-instruct-tft",
|
||||
max_tokens=50,
|
||||
temperature=0.7,
|
||||
p=0.8,
|
||||
)
|
||||
mock_instance.assert_called_once_with(prompt)
|
||||
|
||||
Reference in New Issue
Block a user