|
|
|
import unittest
|
|
|
|
import os
|
|
|
|
from unittest.mock import patch
|
|
|
|
from langchain import HuggingFaceHub, ChatOpenAI
|
|
|
|
|
|
|
|
from swarms.models.llm import LLM
|
|
|
|
|
|
|
|
|
|
|
|
class TestLLM(unittest.TestCase):
|
|
|
|
@patch.object(HuggingFaceHub, "__init__", return_value=None)
|
|
|
|
@patch.object(ChatOpenAI, "__init__", return_value=None)
|
|
|
|
def setUp(self, mock_hf_init, mock_openai_init):
|
|
|
|
self.llm_openai = LLM(openai_api_key="mock_openai_key")
|
|
|
|
self.llm_hf = LLM(
|
|
|
|
hf_repo_id="mock_repo_id", hf_api_token="mock_hf_token"
|
|
|
|
)
|
|
|
|
self.prompt = "Who won the FIFA World Cup in 1998?"
|
|
|
|
|
|
|
|
def test_init(self):
|
|
|
|
self.assertEqual(
|
|
|
|
self.llm_openai.openai_api_key, "mock_openai_key"
|
|
|
|
)
|
|
|
|
self.assertEqual(self.llm_hf.hf_repo_id, "mock_repo_id")
|
|
|
|
self.assertEqual(self.llm_hf.hf_api_token, "mock_hf_token")
|
|
|
|
|
|
|
|
@patch.object(HuggingFaceHub, "run", return_value="France")
|
|
|
|
@patch.object(ChatOpenAI, "run", return_value="France")
|
|
|
|
def test_run(self, mock_hf_run, mock_openai_run):
|
|
|
|
result_openai = self.llm_openai.run(self.prompt)
|
|
|
|
mock_openai_run.assert_called_once()
|
|
|
|
self.assertEqual(result_openai, "France")
|
|
|
|
|
|
|
|
result_hf = self.llm_hf.run(self.prompt)
|
|
|
|
mock_hf_run.assert_called_once()
|
|
|
|
self.assertEqual(result_hf, "France")
|
|
|
|
|
|
|
|
def test_error_on_no_keys(self):
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
LLM()
|
|
|
|
|
|
|
|
@patch.object(os, "environ", {})
|
|
|
|
def test_error_on_missing_hf_token(self):
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
LLM(hf_repo_id="mock_repo_id")
|
|
|
|
|
|
|
|
@patch.dict(
|
|
|
|
os.environ, {"HUGGINGFACEHUB_API_TOKEN": "mock_hf_token"}
|
|
|
|
)
|
|
|
|
def test_hf_token_from_env(self):
|
|
|
|
llm = LLM(hf_repo_id="mock_repo_id")
|
|
|
|
self.assertEqual(llm.hf_api_token, "mock_hf_token")
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main()
|