test_huggingface.py 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import importlib
  2. import os
  3. import pytest
  4. from embedchain.config import BaseLlmConfig
  5. from embedchain.llm.huggingface import HuggingFaceLlm
  6. @pytest.fixture
  7. def huggingface_llm_config():
  8. os.environ["HUGGINGFACE_ACCESS_TOKEN"] = "test_access_token"
  9. config = BaseLlmConfig(model="google/flan-t5-xxl", max_tokens=50, temperature=0.7, top_p=0.8)
  10. yield config
  11. os.environ.pop("HUGGINGFACE_ACCESS_TOKEN")
  12. @pytest.fixture
  13. def huggingface_endpoint_config():
  14. os.environ["HUGGINGFACE_ACCESS_TOKEN"] = "test_access_token"
  15. config = BaseLlmConfig(endpoint="https://api-inference.huggingface.co/models/gpt2", model_kwargs={"device": "cpu"})
  16. yield config
  17. os.environ.pop("HUGGINGFACE_ACCESS_TOKEN")
  18. def test_init_raises_value_error_without_api_key(mocker):
  19. mocker.patch.dict(os.environ, clear=True)
  20. with pytest.raises(ValueError):
  21. HuggingFaceLlm()
  22. def test_get_llm_model_answer_raises_value_error_for_system_prompt(huggingface_llm_config):
  23. llm = HuggingFaceLlm(huggingface_llm_config)
  24. llm.config.system_prompt = "system_prompt"
  25. with pytest.raises(ValueError):
  26. llm.get_llm_model_answer("prompt")
  27. def test_top_p_value_within_range():
  28. config = BaseLlmConfig(top_p=1.0)
  29. with pytest.raises(ValueError):
  30. HuggingFaceLlm._get_answer("test_prompt", config)
  31. def test_dependency_is_imported():
  32. importlib_installed = True
  33. try:
  34. importlib.import_module("huggingface_hub")
  35. except ImportError:
  36. importlib_installed = False
  37. assert importlib_installed
  38. def test_get_llm_model_answer(huggingface_llm_config, mocker):
  39. mocker.patch("embedchain.llm.huggingface.HuggingFaceLlm._get_answer", return_value="Test answer")
  40. llm = HuggingFaceLlm(huggingface_llm_config)
  41. answer = llm.get_llm_model_answer("Test query")
  42. assert answer == "Test answer"
  43. def test_hugging_face_mock(huggingface_llm_config, mocker):
  44. mock_llm_instance = mocker.Mock(return_value="Test answer")
  45. mocker.patch("embedchain.llm.huggingface.HuggingFaceHub", return_value=mock_llm_instance)
  46. llm = HuggingFaceLlm(huggingface_llm_config)
  47. answer = llm.get_llm_model_answer("Test query")
  48. assert answer == "Test answer"
  49. mock_llm_instance.assert_called_once_with("Test query")
  50. def test_custom_endpoint(huggingface_endpoint_config, mocker):
  51. mock_llm_instance = mocker.Mock(return_value="Test answer")
  52. mocker.patch("embedchain.llm.huggingface.HuggingFaceEndpoint", return_value=mock_llm_instance)
  53. llm = HuggingFaceLlm(huggingface_endpoint_config)
  54. answer = llm.get_llm_model_answer("Test query")
  55. assert answer == "Test answer"
  56. mock_llm_instance.assert_called_once_with("Test query")