test_together.py 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import os
  2. import pytest
  3. from embedchain.config import BaseLlmConfig
  4. from embedchain.llm.together import TogetherLlm
  5. @pytest.fixture
  6. def together_llm_config():
  7. os.environ["TOGETHER_API_KEY"] = "test_api_key"
  8. config = BaseLlmConfig(model="together-ai-up-to-3b", max_tokens=50, temperature=0.7, top_p=0.8)
  9. yield config
  10. os.environ.pop("TOGETHER_API_KEY")
  11. def test_init_raises_value_error_without_api_key(mocker):
  12. mocker.patch.dict(os.environ, clear=True)
  13. with pytest.raises(ValueError):
  14. TogetherLlm()
  15. def test_get_llm_model_answer_raises_value_error_for_system_prompt(together_llm_config):
  16. llm = TogetherLlm(together_llm_config)
  17. llm.config.system_prompt = "system_prompt"
  18. with pytest.raises(ValueError):
  19. llm.get_llm_model_answer("prompt")
  20. def test_get_llm_model_answer(together_llm_config, mocker):
  21. mocker.patch("embedchain.llm.together.TogetherLlm._get_answer", return_value="Test answer")
  22. llm = TogetherLlm(together_llm_config)
  23. answer = llm.get_llm_model_answer("Test query")
  24. assert answer == "Test answer"
  25. def test_get_llm_model_answer_with_token_usage(together_llm_config, mocker):
  26. test_config = BaseLlmConfig(
  27. temperature=together_llm_config.temperature,
  28. max_tokens=together_llm_config.max_tokens,
  29. top_p=together_llm_config.top_p,
  30. model=together_llm_config.model,
  31. token_usage=True,
  32. )
  33. mocker.patch(
  34. "embedchain.llm.together.TogetherLlm._get_answer",
  35. return_value=("Test answer", {"prompt_tokens": 1, "completion_tokens": 2}),
  36. )
  37. llm = TogetherLlm(test_config)
  38. answer, token_info = llm.get_llm_model_answer("Test query")
  39. assert answer == "Test answer"
  40. assert token_info == {
  41. "prompt_tokens": 1,
  42. "completion_tokens": 2,
  43. "total_tokens": 3,
  44. "total_cost": 3e-07,
  45. "cost_currency": "USD",
  46. }
  47. def test_get_answer_mocked_together(together_llm_config, mocker):
  48. mocked_together = mocker.patch("embedchain.llm.together.ChatTogether")
  49. mock_instance = mocked_together.return_value
  50. mock_instance.invoke.return_value.content = "Mocked answer"
  51. llm = TogetherLlm(together_llm_config)
  52. prompt = "Test query"
  53. answer = llm.get_llm_model_answer(prompt)
  54. assert answer == "Mocked answer"