test_ollama.py 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839
  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.OllamaLlm._get_answer", return_value="Test answer")
  10. llm = OllamaLlm(ollama_llm_config)
  11. answer = llm.get_llm_model_answer("Test query")
  12. assert answer == "Test answer"
  13. def test_get_answer_mocked_ollama(ollama_llm_config, mocker):
  14. mocked_ollama = mocker.patch("embedchain.llm.ollama.Ollama")
  15. mock_instance = mocked_ollama.return_value
  16. mock_instance.return_value = "Mocked answer"
  17. llm = OllamaLlm(ollama_llm_config)
  18. prompt = "Test query"
  19. answer = llm.get_llm_model_answer(prompt)
  20. assert answer == "Mocked answer"
  21. mocked_ollama.assert_called_once_with(
  22. model="llama2",
  23. system=None,
  24. temperature=0.7,
  25. top_p=0.8,
  26. callback_manager=mocker.ANY, # Use mocker.ANY to ignore the exact instance
  27. )
  28. mock_instance.assert_called_once_with(prompt)