test_ollama.py 1.1 KB

123456789101112131415161718192021222324252627282930313233
  1. import pytest
  2. from embedchain.config import BaseLlmConfig
  3. from embedchain.llm.ollama import OllamaLlm
  4. @pytest.fixture
  5. def ollama_llm_config():
  6. config = BaseLlmConfig(model="llama2", temperature=0.7, top_p=0.8, stream=True, system_prompt=None)
  7. yield config
  8. def test_get_llm_model_answer(ollama_llm_config, mocker):
  9. mocker.patch("embedchain.llm.ollama.Client.list", return_value={"models": [{"name": "llama2"}]})
  10. mocker.patch("embedchain.llm.ollama.OllamaLlm._get_answer", return_value="Test answer")
  11. llm = OllamaLlm(ollama_llm_config)
  12. answer = llm.get_llm_model_answer("Test query")
  13. assert answer == "Test answer"
  14. def test_get_answer_mocked_ollama(ollama_llm_config, mocker):
  15. mocker.patch("embedchain.llm.ollama.Client.list", return_value={"models": [{"name": "llama2"}]})
  16. mocked_ollama = mocker.patch("embedchain.llm.ollama.Ollama")
  17. mock_instance = mocked_ollama.return_value
  18. mock_instance.invoke.return_value = "Mocked answer"
  19. llm = OllamaLlm(ollama_llm_config)
  20. prompt = "Test query"
  21. answer = llm.get_llm_model_answer(prompt)
  22. assert answer == "Mocked answer"