test_llm.py 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. import os
  2. from collections.abc import Generator
  3. import pytest
  4. from core.model_runtime.entities.llm_entities import LLMResult, LLMResultChunk, LLMResultChunkDelta
  5. from core.model_runtime.entities.message_entities import (
  6. AssistantPromptMessage,
  7. ImagePromptMessageContent,
  8. PromptMessageTool,
  9. SystemPromptMessage,
  10. TextPromptMessageContent,
  11. UserPromptMessage,
  12. )
  13. from core.model_runtime.errors.validate import CredentialsValidateFailedError
  14. from core.model_runtime.model_providers.azure_openai.llm.llm import AzureOpenAILargeLanguageModel
  15. from tests.integration_tests.model_runtime.__mock.openai import setup_openai_mock
  16. @pytest.mark.parametrize("setup_openai_mock", [["chat"]], indirect=True)
  17. def test_validate_credentials_for_chat_model(setup_openai_mock):
  18. model = AzureOpenAILargeLanguageModel()
  19. with pytest.raises(CredentialsValidateFailedError):
  20. model.validate_credentials(
  21. model="gpt35",
  22. credentials={
  23. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  24. "openai_api_key": "invalid_key",
  25. "base_model_name": "gpt-35-turbo",
  26. },
  27. )
  28. model.validate_credentials(
  29. model="gpt35",
  30. credentials={
  31. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  32. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  33. "base_model_name": "gpt-35-turbo",
  34. },
  35. )
  36. @pytest.mark.parametrize("setup_openai_mock", [["completion"]], indirect=True)
  37. def test_validate_credentials_for_completion_model(setup_openai_mock):
  38. model = AzureOpenAILargeLanguageModel()
  39. with pytest.raises(CredentialsValidateFailedError):
  40. model.validate_credentials(
  41. model="gpt-35-turbo-instruct",
  42. credentials={
  43. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  44. "openai_api_key": "invalid_key",
  45. "base_model_name": "gpt-35-turbo-instruct",
  46. },
  47. )
  48. model.validate_credentials(
  49. model="gpt-35-turbo-instruct",
  50. credentials={
  51. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  52. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  53. "base_model_name": "gpt-35-turbo-instruct",
  54. },
  55. )
  56. @pytest.mark.parametrize("setup_openai_mock", [["completion"]], indirect=True)
  57. def test_invoke_completion_model(setup_openai_mock):
  58. model = AzureOpenAILargeLanguageModel()
  59. result = model.invoke(
  60. model="gpt-35-turbo-instruct",
  61. credentials={
  62. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  63. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  64. "base_model_name": "gpt-35-turbo-instruct",
  65. },
  66. prompt_messages=[UserPromptMessage(content="Hello World!")],
  67. model_parameters={"temperature": 0.0, "max_tokens": 1},
  68. stream=False,
  69. user="abc-123",
  70. )
  71. assert isinstance(result, LLMResult)
  72. assert len(result.message.content) > 0
  73. @pytest.mark.parametrize("setup_openai_mock", [["completion"]], indirect=True)
  74. def test_invoke_stream_completion_model(setup_openai_mock):
  75. model = AzureOpenAILargeLanguageModel()
  76. result = model.invoke(
  77. model="gpt-35-turbo-instruct",
  78. credentials={
  79. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  80. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  81. "base_model_name": "gpt-35-turbo-instruct",
  82. },
  83. prompt_messages=[UserPromptMessage(content="Hello World!")],
  84. model_parameters={"temperature": 0.0, "max_tokens": 100},
  85. stream=True,
  86. user="abc-123",
  87. )
  88. assert isinstance(result, Generator)
  89. for chunk in result:
  90. assert isinstance(chunk, LLMResultChunk)
  91. assert isinstance(chunk.delta, LLMResultChunkDelta)
  92. assert isinstance(chunk.delta.message, AssistantPromptMessage)
  93. assert len(chunk.delta.message.content) > 0 if chunk.delta.finish_reason is None else True
  94. @pytest.mark.parametrize("setup_openai_mock", [["chat"]], indirect=True)
  95. def test_invoke_chat_model(setup_openai_mock):
  96. model = AzureOpenAILargeLanguageModel()
  97. result = model.invoke(
  98. model="gpt35",
  99. credentials={
  100. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  101. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  102. "base_model_name": "gpt-35-turbo",
  103. },
  104. prompt_messages=[
  105. SystemPromptMessage(
  106. content="You are a helpful AI assistant.",
  107. ),
  108. UserPromptMessage(content="Hello World!"),
  109. ],
  110. model_parameters={
  111. "temperature": 0.0,
  112. "top_p": 1.0,
  113. "presence_penalty": 0.0,
  114. "frequency_penalty": 0.0,
  115. "max_tokens": 10,
  116. },
  117. stop=["How"],
  118. stream=False,
  119. user="abc-123",
  120. )
  121. assert isinstance(result, LLMResult)
  122. assert len(result.message.content) > 0
  123. @pytest.mark.parametrize("setup_openai_mock", [["chat"]], indirect=True)
  124. def test_invoke_stream_chat_model(setup_openai_mock):
  125. model = AzureOpenAILargeLanguageModel()
  126. result = model.invoke(
  127. model="gpt35",
  128. credentials={
  129. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  130. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  131. "base_model_name": "gpt-35-turbo",
  132. },
  133. prompt_messages=[
  134. SystemPromptMessage(
  135. content="You are a helpful AI assistant.",
  136. ),
  137. UserPromptMessage(content="Hello World!"),
  138. ],
  139. model_parameters={"temperature": 0.0, "max_tokens": 100},
  140. stream=True,
  141. user="abc-123",
  142. )
  143. assert isinstance(result, Generator)
  144. for chunk in result:
  145. assert isinstance(chunk, LLMResultChunk)
  146. assert isinstance(chunk.delta, LLMResultChunkDelta)
  147. assert isinstance(chunk.delta.message, AssistantPromptMessage)
  148. if chunk.delta.finish_reason is not None:
  149. assert chunk.delta.usage is not None
  150. assert chunk.delta.usage.completion_tokens > 0
  151. @pytest.mark.parametrize("setup_openai_mock", [["chat"]], indirect=True)
  152. def test_invoke_chat_model_with_vision(setup_openai_mock):
  153. model = AzureOpenAILargeLanguageModel()
  154. result = model.invoke(
  155. model="gpt-4v",
  156. credentials={
  157. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  158. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  159. "base_model_name": "gpt-4-vision-preview",
  160. },
  161. prompt_messages=[
  162. SystemPromptMessage(
  163. content="You are a helpful AI assistant.",
  164. ),
  165. UserPromptMessage(
  166. content=[
  167. TextPromptMessageContent(
  168. data="Hello World!",
  169. ),
  170. ImagePromptMessageContent(
  171. data=""
  172. ),
  173. ]
  174. ),
  175. ],
  176. model_parameters={"temperature": 0.0, "max_tokens": 100},
  177. stream=False,
  178. user="abc-123",
  179. )
  180. assert isinstance(result, LLMResult)
  181. assert len(result.message.content) > 0
  182. @pytest.mark.parametrize("setup_openai_mock", [["chat"]], indirect=True)
  183. def test_invoke_chat_model_with_tools(setup_openai_mock):
  184. model = AzureOpenAILargeLanguageModel()
  185. result = model.invoke(
  186. model="gpt-35-turbo",
  187. credentials={
  188. "openai_api_base": os.environ.get("AZURE_OPENAI_API_BASE"),
  189. "openai_api_key": os.environ.get("AZURE_OPENAI_API_KEY"),
  190. "base_model_name": "gpt-35-turbo",
  191. },
  192. prompt_messages=[
  193. SystemPromptMessage(
  194. content="You are a helpful AI assistant.",
  195. ),
  196. UserPromptMessage(
  197. content="what's the weather today in London?",
  198. ),
  199. ],
  200. model_parameters={"temperature": 0.0, "max_tokens": 100},
  201. tools=[
  202. PromptMessageTool(
  203. name="get_weather",
  204. description="Determine weather in my location",
  205. parameters={
  206. "type": "object",
  207. "properties": {
  208. "location": {"type": "string", "description": "The city and state e.g. San Francisco, CA"},
  209. "unit": {"type": "string", "enum": ["c", "f"]},
  210. },
  211. "required": ["location"],
  212. },
  213. ),
  214. PromptMessageTool(
  215. name="get_stock_price",
  216. description="Get the current stock price",
  217. parameters={
  218. "type": "object",
  219. "properties": {"symbol": {"type": "string", "description": "The stock symbol"}},
  220. "required": ["symbol"],
  221. },
  222. ),
  223. ],
  224. stream=False,
  225. user="abc-123",
  226. )
  227. assert isinstance(result, LLMResult)
  228. assert isinstance(result.message, AssistantPromptMessage)
  229. assert len(result.message.tool_calls) > 0
  230. def test_get_num_tokens():
  231. model = AzureOpenAILargeLanguageModel()
  232. num_tokens = model.get_num_tokens(
  233. model="gpt-35-turbo-instruct",
  234. credentials={"base_model_name": "gpt-35-turbo-instruct"},
  235. prompt_messages=[UserPromptMessage(content="Hello World!")],
  236. )
  237. assert num_tokens == 3
  238. num_tokens = model.get_num_tokens(
  239. model="gpt35",
  240. credentials={"base_model_name": "gpt-35-turbo"},
  241. prompt_messages=[
  242. SystemPromptMessage(
  243. content="You are a helpful AI assistant.",
  244. ),
  245. UserPromptMessage(content="Hello World!"),
  246. ],
  247. )
  248. assert num_tokens == 21