google-genai 1.55.0__py3-none-any.whl → 1.56.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (241) hide show
  1. google/genai/_interactions/_base_client.py +8 -2
  2. google/genai/_interactions/resources/interactions.py +6 -6
  3. google/genai/_interactions/types/__init__.py +2 -0
  4. google/genai/_interactions/types/audio_content.py +0 -1
  5. google/genai/_interactions/types/audio_content_param.py +0 -1
  6. google/genai/_interactions/types/code_execution_call_content.py +0 -1
  7. google/genai/_interactions/types/code_execution_call_content_param.py +0 -1
  8. google/genai/_interactions/types/code_execution_result_content.py +0 -1
  9. google/genai/_interactions/types/code_execution_result_content_param.py +0 -1
  10. google/genai/_interactions/types/content_delta.py +7 -23
  11. google/genai/_interactions/types/deep_research_agent_config.py +0 -1
  12. google/genai/_interactions/types/deep_research_agent_config_param.py +0 -1
  13. google/genai/_interactions/types/document_content.py +3 -2
  14. google/genai/_interactions/types/document_content_param.py +3 -2
  15. google/genai/{tests/__init__.py → _interactions/types/document_mime_type.py} +5 -3
  16. google/genai/{tests/afc/__init__.py → _interactions/types/document_mime_type_param.py} +8 -4
  17. google/genai/_interactions/types/dynamic_agent_config.py +0 -1
  18. google/genai/_interactions/types/dynamic_agent_config_param.py +0 -1
  19. google/genai/_interactions/types/file_search_result_content.py +0 -1
  20. google/genai/_interactions/types/file_search_result_content_param.py +0 -1
  21. google/genai/_interactions/types/function_call_content.py +0 -1
  22. google/genai/_interactions/types/function_call_content_param.py +0 -1
  23. google/genai/_interactions/types/function_result_content.py +1 -2
  24. google/genai/_interactions/types/function_result_content_param.py +1 -2
  25. google/genai/_interactions/types/google_search_call_content.py +0 -1
  26. google/genai/_interactions/types/google_search_call_content_param.py +0 -1
  27. google/genai/_interactions/types/google_search_result_content.py +0 -1
  28. google/genai/_interactions/types/google_search_result_content_param.py +0 -1
  29. google/genai/_interactions/types/image_content.py +1 -2
  30. google/genai/_interactions/types/image_content_param.py +1 -2
  31. google/genai/_interactions/types/mcp_server_tool_call_content.py +0 -1
  32. google/genai/_interactions/types/mcp_server_tool_call_content_param.py +0 -1
  33. google/genai/_interactions/types/mcp_server_tool_result_content.py +1 -2
  34. google/genai/_interactions/types/mcp_server_tool_result_content_param.py +1 -2
  35. google/genai/_interactions/types/text_content.py +0 -1
  36. google/genai/_interactions/types/text_content_param.py +0 -1
  37. google/genai/_interactions/types/thinking_level.py +1 -1
  38. google/genai/_interactions/types/thought_content.py +0 -1
  39. google/genai/_interactions/types/thought_content_param.py +0 -1
  40. google/genai/_interactions/types/url_context_call_content.py +0 -1
  41. google/genai/_interactions/types/url_context_call_content_param.py +0 -1
  42. google/genai/_interactions/types/url_context_result_content.py +0 -1
  43. google/genai/_interactions/types/url_context_result_content_param.py +0 -1
  44. google/genai/_interactions/types/video_content.py +1 -2
  45. google/genai/_interactions/types/video_content_param.py +1 -2
  46. google/genai/_live_converters.py +2 -30
  47. google/genai/client.py +3 -1
  48. google/genai/models.py +2 -29
  49. google/genai/tunings.py +1 -27
  50. google/genai/types.py +20 -22
  51. google/genai/version.py +1 -1
  52. {google_genai-1.55.0.dist-info → google_genai-1.56.0.dist-info}/METADATA +224 -22
  53. google_genai-1.56.0.dist-info/RECORD +162 -0
  54. google/genai/tests/afc/test_convert_if_exist_pydantic_model.py +0 -309
  55. google/genai/tests/afc/test_convert_number_values_for_function_call_args.py +0 -63
  56. google/genai/tests/afc/test_find_afc_incompatible_tool_indexes.py +0 -240
  57. google/genai/tests/afc/test_generate_content_stream_afc.py +0 -530
  58. google/genai/tests/afc/test_generate_content_stream_afc_thoughts.py +0 -77
  59. google/genai/tests/afc/test_get_function_map.py +0 -176
  60. google/genai/tests/afc/test_get_function_response_parts.py +0 -277
  61. google/genai/tests/afc/test_get_max_remote_calls_for_afc.py +0 -130
  62. google/genai/tests/afc/test_invoke_function_from_dict_args.py +0 -241
  63. google/genai/tests/afc/test_raise_error_for_afc_incompatible_config.py +0 -159
  64. google/genai/tests/afc/test_should_append_afc_history.py +0 -53
  65. google/genai/tests/afc/test_should_disable_afc.py +0 -214
  66. google/genai/tests/batches/__init__.py +0 -17
  67. google/genai/tests/batches/test_cancel.py +0 -77
  68. google/genai/tests/batches/test_create.py +0 -78
  69. google/genai/tests/batches/test_create_with_bigquery.py +0 -113
  70. google/genai/tests/batches/test_create_with_file.py +0 -82
  71. google/genai/tests/batches/test_create_with_gcs.py +0 -125
  72. google/genai/tests/batches/test_create_with_inlined_requests.py +0 -255
  73. google/genai/tests/batches/test_delete.py +0 -86
  74. google/genai/tests/batches/test_embedding.py +0 -157
  75. google/genai/tests/batches/test_get.py +0 -78
  76. google/genai/tests/batches/test_list.py +0 -79
  77. google/genai/tests/caches/__init__.py +0 -17
  78. google/genai/tests/caches/constants.py +0 -29
  79. google/genai/tests/caches/test_create.py +0 -210
  80. google/genai/tests/caches/test_create_custom_url.py +0 -105
  81. google/genai/tests/caches/test_delete.py +0 -54
  82. google/genai/tests/caches/test_delete_custom_url.py +0 -52
  83. google/genai/tests/caches/test_get.py +0 -94
  84. google/genai/tests/caches/test_get_custom_url.py +0 -52
  85. google/genai/tests/caches/test_list.py +0 -68
  86. google/genai/tests/caches/test_update.py +0 -70
  87. google/genai/tests/caches/test_update_custom_url.py +0 -58
  88. google/genai/tests/chats/__init__.py +0 -1
  89. google/genai/tests/chats/test_get_history.py +0 -597
  90. google/genai/tests/chats/test_send_message.py +0 -844
  91. google/genai/tests/chats/test_validate_response.py +0 -90
  92. google/genai/tests/client/__init__.py +0 -17
  93. google/genai/tests/client/test_async_stream.py +0 -427
  94. google/genai/tests/client/test_client_close.py +0 -197
  95. google/genai/tests/client/test_client_initialization.py +0 -1687
  96. google/genai/tests/client/test_client_requests.py +0 -355
  97. google/genai/tests/client/test_custom_client.py +0 -77
  98. google/genai/tests/client/test_http_options.py +0 -178
  99. google/genai/tests/client/test_replay_client_equality.py +0 -168
  100. google/genai/tests/client/test_retries.py +0 -846
  101. google/genai/tests/client/test_upload_errors.py +0 -136
  102. google/genai/tests/common/__init__.py +0 -17
  103. google/genai/tests/common/test_common.py +0 -954
  104. google/genai/tests/conftest.py +0 -162
  105. google/genai/tests/documents/__init__.py +0 -17
  106. google/genai/tests/documents/test_delete.py +0 -51
  107. google/genai/tests/documents/test_get.py +0 -85
  108. google/genai/tests/documents/test_list.py +0 -72
  109. google/genai/tests/errors/__init__.py +0 -1
  110. google/genai/tests/errors/test_api_error.py +0 -417
  111. google/genai/tests/file_search_stores/__init__.py +0 -17
  112. google/genai/tests/file_search_stores/test_create.py +0 -66
  113. google/genai/tests/file_search_stores/test_delete.py +0 -64
  114. google/genai/tests/file_search_stores/test_get.py +0 -94
  115. google/genai/tests/file_search_stores/test_import_file.py +0 -112
  116. google/genai/tests/file_search_stores/test_list.py +0 -57
  117. google/genai/tests/file_search_stores/test_upload_to_file_search_store.py +0 -141
  118. google/genai/tests/files/__init__.py +0 -17
  119. google/genai/tests/files/test_delete.py +0 -46
  120. google/genai/tests/files/test_download.py +0 -85
  121. google/genai/tests/files/test_get.py +0 -46
  122. google/genai/tests/files/test_list.py +0 -72
  123. google/genai/tests/files/test_upload.py +0 -255
  124. google/genai/tests/imports/test_no_optional_imports.py +0 -28
  125. google/genai/tests/interactions/test_integration.py +0 -80
  126. google/genai/tests/live/__init__.py +0 -16
  127. google/genai/tests/live/test_live.py +0 -2177
  128. google/genai/tests/live/test_live_music.py +0 -362
  129. google/genai/tests/live/test_live_response.py +0 -163
  130. google/genai/tests/live/test_send_client_content.py +0 -147
  131. google/genai/tests/live/test_send_realtime_input.py +0 -268
  132. google/genai/tests/live/test_send_tool_response.py +0 -222
  133. google/genai/tests/local_tokenizer/__init__.py +0 -17
  134. google/genai/tests/local_tokenizer/test_local_tokenizer.py +0 -343
  135. google/genai/tests/local_tokenizer/test_local_tokenizer_loader.py +0 -235
  136. google/genai/tests/mcp/__init__.py +0 -17
  137. google/genai/tests/mcp/test_has_mcp_tool_usage.py +0 -89
  138. google/genai/tests/mcp/test_mcp_to_gemini_tools.py +0 -191
  139. google/genai/tests/mcp/test_parse_config_for_mcp_sessions.py +0 -201
  140. google/genai/tests/mcp/test_parse_config_for_mcp_usage.py +0 -130
  141. google/genai/tests/mcp/test_set_mcp_usage_header.py +0 -72
  142. google/genai/tests/models/__init__.py +0 -17
  143. google/genai/tests/models/constants.py +0 -8
  144. google/genai/tests/models/test_compute_tokens.py +0 -120
  145. google/genai/tests/models/test_count_tokens.py +0 -159
  146. google/genai/tests/models/test_delete.py +0 -107
  147. google/genai/tests/models/test_edit_image.py +0 -264
  148. google/genai/tests/models/test_embed_content.py +0 -94
  149. google/genai/tests/models/test_function_call_streaming.py +0 -442
  150. google/genai/tests/models/test_generate_content.py +0 -2502
  151. google/genai/tests/models/test_generate_content_cached_content.py +0 -132
  152. google/genai/tests/models/test_generate_content_config_zero_value.py +0 -103
  153. google/genai/tests/models/test_generate_content_from_apikey.py +0 -44
  154. google/genai/tests/models/test_generate_content_http_options.py +0 -40
  155. google/genai/tests/models/test_generate_content_image_generation.py +0 -143
  156. google/genai/tests/models/test_generate_content_mcp.py +0 -343
  157. google/genai/tests/models/test_generate_content_media_resolution.py +0 -97
  158. google/genai/tests/models/test_generate_content_model.py +0 -139
  159. google/genai/tests/models/test_generate_content_part.py +0 -821
  160. google/genai/tests/models/test_generate_content_thought.py +0 -76
  161. google/genai/tests/models/test_generate_content_tools.py +0 -1761
  162. google/genai/tests/models/test_generate_images.py +0 -191
  163. google/genai/tests/models/test_generate_videos.py +0 -759
  164. google/genai/tests/models/test_get.py +0 -104
  165. google/genai/tests/models/test_list.py +0 -233
  166. google/genai/tests/models/test_recontext_image.py +0 -189
  167. google/genai/tests/models/test_segment_image.py +0 -148
  168. google/genai/tests/models/test_update.py +0 -95
  169. google/genai/tests/models/test_upscale_image.py +0 -157
  170. google/genai/tests/operations/__init__.py +0 -17
  171. google/genai/tests/operations/test_get.py +0 -38
  172. google/genai/tests/public_samples/__init__.py +0 -17
  173. google/genai/tests/public_samples/test_gemini_text_only.py +0 -34
  174. google/genai/tests/pytest_helper.py +0 -229
  175. google/genai/tests/shared/__init__.py +0 -16
  176. google/genai/tests/shared/batches/__init__.py +0 -14
  177. google/genai/tests/shared/batches/test_create_delete.py +0 -57
  178. google/genai/tests/shared/batches/test_create_get_cancel.py +0 -56
  179. google/genai/tests/shared/batches/test_list.py +0 -40
  180. google/genai/tests/shared/caches/__init__.py +0 -14
  181. google/genai/tests/shared/caches/test_create_get_delete.py +0 -67
  182. google/genai/tests/shared/caches/test_create_update_get.py +0 -71
  183. google/genai/tests/shared/caches/test_list.py +0 -40
  184. google/genai/tests/shared/chats/__init__.py +0 -14
  185. google/genai/tests/shared/chats/test_send_message.py +0 -48
  186. google/genai/tests/shared/chats/test_send_message_stream.py +0 -50
  187. google/genai/tests/shared/files/__init__.py +0 -14
  188. google/genai/tests/shared/files/test_list.py +0 -41
  189. google/genai/tests/shared/files/test_upload_get_delete.py +0 -54
  190. google/genai/tests/shared/models/__init__.py +0 -14
  191. google/genai/tests/shared/models/test_compute_tokens.py +0 -41
  192. google/genai/tests/shared/models/test_count_tokens.py +0 -40
  193. google/genai/tests/shared/models/test_edit_image.py +0 -67
  194. google/genai/tests/shared/models/test_embed.py +0 -40
  195. google/genai/tests/shared/models/test_generate_content.py +0 -39
  196. google/genai/tests/shared/models/test_generate_content_stream.py +0 -54
  197. google/genai/tests/shared/models/test_generate_images.py +0 -40
  198. google/genai/tests/shared/models/test_generate_videos.py +0 -38
  199. google/genai/tests/shared/models/test_list.py +0 -37
  200. google/genai/tests/shared/models/test_recontext_image.py +0 -55
  201. google/genai/tests/shared/models/test_segment_image.py +0 -52
  202. google/genai/tests/shared/models/test_upscale_image.py +0 -52
  203. google/genai/tests/shared/tunings/__init__.py +0 -16
  204. google/genai/tests/shared/tunings/test_create.py +0 -46
  205. google/genai/tests/shared/tunings/test_create_get_cancel.py +0 -56
  206. google/genai/tests/shared/tunings/test_list.py +0 -39
  207. google/genai/tests/tokens/__init__.py +0 -16
  208. google/genai/tests/tokens/test_create.py +0 -154
  209. google/genai/tests/transformers/__init__.py +0 -17
  210. google/genai/tests/transformers/test_blobs.py +0 -71
  211. google/genai/tests/transformers/test_bytes.py +0 -15
  212. google/genai/tests/transformers/test_duck_type.py +0 -96
  213. google/genai/tests/transformers/test_function_responses.py +0 -72
  214. google/genai/tests/transformers/test_schema.py +0 -653
  215. google/genai/tests/transformers/test_t_batch.py +0 -286
  216. google/genai/tests/transformers/test_t_content.py +0 -160
  217. google/genai/tests/transformers/test_t_contents.py +0 -398
  218. google/genai/tests/transformers/test_t_part.py +0 -85
  219. google/genai/tests/transformers/test_t_parts.py +0 -87
  220. google/genai/tests/transformers/test_t_tool.py +0 -157
  221. google/genai/tests/transformers/test_t_tools.py +0 -195
  222. google/genai/tests/tunings/__init__.py +0 -16
  223. google/genai/tests/tunings/test_cancel.py +0 -39
  224. google/genai/tests/tunings/test_end_to_end.py +0 -106
  225. google/genai/tests/tunings/test_get.py +0 -67
  226. google/genai/tests/tunings/test_list.py +0 -75
  227. google/genai/tests/tunings/test_tune.py +0 -268
  228. google/genai/tests/types/__init__.py +0 -16
  229. google/genai/tests/types/test_bytes_internal.py +0 -271
  230. google/genai/tests/types/test_bytes_type.py +0 -152
  231. google/genai/tests/types/test_future.py +0 -101
  232. google/genai/tests/types/test_optional_types.py +0 -36
  233. google/genai/tests/types/test_part_type.py +0 -616
  234. google/genai/tests/types/test_schema_from_json_schema.py +0 -417
  235. google/genai/tests/types/test_schema_json_schema.py +0 -468
  236. google/genai/tests/types/test_types.py +0 -2903
  237. google_genai-1.55.0.dist-info/RECORD +0 -345
  238. /google/genai/{tests/interactions/__init__.py → _interactions/py.typed} +0 -0
  239. {google_genai-1.55.0.dist-info → google_genai-1.56.0.dist-info}/WHEEL +0 -0
  240. {google_genai-1.55.0.dist-info → google_genai-1.56.0.dist-info}/licenses/LICENSE +0 -0
  241. {google_genai-1.55.0.dist-info → google_genai-1.56.0.dist-info}/top_level.txt +0 -0
@@ -1,343 +0,0 @@
1
- # Copyright 2025 Google LLC
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
- #
15
-
16
- from typing import Any
17
- import pytest
18
- from ... import _transformers as t
19
- from ... import errors
20
- from ... import types
21
- from .. import pytest_helper
22
-
23
- try:
24
- from mcp import types as mcp_types
25
- from mcp import ClientSession as McpClientSession
26
- except ImportError as e:
27
- import sys
28
-
29
- if sys.version_info < (3, 10):
30
- raise ImportError(
31
- 'MCP Tool requires Python 3.10 or above. Please upgrade your Python'
32
- ' version.'
33
- ) from e
34
- else:
35
- raise e
36
-
37
- pytestmark = pytest_helper.setup(
38
- file=__file__,
39
- globals_for_file=globals(),
40
- test_method='models.generate_content',
41
- )
42
-
43
-
44
- # Cannot be included in test_table because MCP integration is only supported
45
- # in the Python SDK.
46
- @pytest.mark.asyncio
47
- async def test_mcp_tools_async(client):
48
- response = await client.aio.models.generate_content(
49
- model='gemini-2.5-flash',
50
- contents=t.t_contents('What is the weather in Boston?'),
51
- config={
52
- 'tools': [
53
- mcp_types.Tool(
54
- name='get_weather',
55
- description='Get the weather in a city.',
56
- inputSchema={
57
- 'type': 'object',
58
- 'properties': {'location': {'type': 'string'}},
59
- },
60
- )
61
- ],
62
- },
63
- )
64
- assert response.function_calls == [
65
- types.FunctionCall(
66
- name='get_weather',
67
- args={'location': 'Boston'},
68
- )
69
- ]
70
-
71
-
72
- @pytest.mark.asyncio
73
- async def test_mcp_tools_with_custom_headers_async(client):
74
- config = {
75
- 'http_options': {
76
- 'headers': {
77
- 'x-goog-api-client': 'google-genai-sdk/1.0.0 gl-python/1.0.0',
78
- },
79
- },
80
- 'tools': [
81
- mcp_types.Tool(
82
- name='get_weather',
83
- description='Get the weather in a city.',
84
- inputSchema={
85
- 'type': 'object',
86
- 'properties': {'location': {'type': 'string'}},
87
- },
88
- )
89
- ],
90
- }
91
- response = await client.aio.models.generate_content(
92
- model='gemini-2.5-flash',
93
- contents=t.t_contents('What is the weather in Boston?'),
94
- config=config,
95
- )
96
- assert response.function_calls == [
97
- types.FunctionCall(
98
- name='get_weather',
99
- args={'location': 'Boston'},
100
- )
101
- ]
102
- # Assert config is not modified.
103
- assert config['http_options']['headers'] == {
104
- 'x-goog-api-client': 'google-genai-sdk/1.0.0 gl-python/1.0.0'
105
- }
106
-
107
-
108
- @pytest.mark.asyncio
109
- async def test_mcp_tools_subsequent_calls_async(client):
110
- class MockMcpClientSession(McpClientSession):
111
-
112
- def __init__(self):
113
- self._read_stream = None
114
- self._write_stream = None
115
-
116
- async def list_tools(self):
117
- return mcp_types.ListToolsResult(
118
- tools=[
119
- mcp_types.Tool(
120
- name='get_weather',
121
- description='Get the weather in a city.',
122
- inputSchema={
123
- 'type': 'object',
124
- 'properties': {'location': {'type': 'string'}},
125
- },
126
- ),
127
- mcp_types.Tool(
128
- name='add_numbers',
129
- description='Add two numbers together.',
130
- inputSchema={
131
- 'type': 'object',
132
- 'properties': {
133
- 'a': {'type': 'number'},
134
- 'b': {'type': 'number'},
135
- },
136
- },
137
- ),
138
- ]
139
- )
140
-
141
- async def call_tool(
142
- self,
143
- name: str,
144
- arguments: dict[str, Any],
145
- ):
146
- if name == 'get_weather':
147
- return mcp_types.CallToolResult(
148
- content=[mcp_types.TextContent(type='text', text='Sunny')]
149
- )
150
- else:
151
- return mcp_types.CallToolResult(
152
- content=[mcp_types.TextContent(type='text', text='100')]
153
- )
154
-
155
- config = {
156
- 'tools': [MockMcpClientSession()],
157
- }
158
-
159
- response = await client.aio.models.generate_content(
160
- model='gemini-2.5-flash',
161
- contents=t.t_contents('What is the weather in Boston?'),
162
- config=config,
163
- )
164
- assert 'sunny' in response.text.lower()
165
-
166
- response_2 = await client.aio.models.generate_content(
167
- model='gemini-2.5-flash',
168
- contents=t.t_contents('What is 50 + 50?'),
169
- config=config,
170
- )
171
- assert '100' in response_2.text
172
-
173
-
174
- @pytest.mark.asyncio
175
- async def test_mcp_tools_duplicate_tool_name_raises_error(client):
176
- class MockMcpClientSession(McpClientSession):
177
-
178
- def __init__(self):
179
- self._read_stream = None
180
- self._write_stream = None
181
-
182
- async def list_tools(self):
183
- return mcp_types.ListToolsResult(
184
- tools=[
185
- mcp_types.Tool(
186
- name='get_weather',
187
- description='Get the weather in a city.',
188
- inputSchema={
189
- 'type': 'object',
190
- 'properties': {'location': {'type': 'string'}},
191
- },
192
- ),
193
- mcp_types.Tool(
194
- name='get_weather',
195
- description='Different tool to get the weather.',
196
- inputSchema={
197
- 'type': 'object',
198
- 'properties': {'location': {'type': 'string'}},
199
- },
200
- ),
201
- ]
202
- )
203
-
204
- with pytest.raises(ValueError):
205
- await client.aio.models.generate_content(
206
- model='gemini-2.5-flash',
207
- contents=t.t_contents('What is the weather in Boston?'),
208
- config={
209
- 'tools': [MockMcpClientSession()],
210
- },
211
- )
212
-
213
-
214
- def test_mcp_tools_synchronous_call(client):
215
- response = client.models.generate_content(
216
- model='gemini-2.5-flash',
217
- contents=t.t_contents('What is the weather in Boston?'),
218
- config={
219
- 'tools': [
220
- mcp_types.Tool(
221
- name='get_weather',
222
- description='Get the weather in a city.',
223
- inputSchema={
224
- 'type': 'object',
225
- 'properties': {'location': {'type': 'string'}},
226
- },
227
- )
228
- ]
229
- },
230
- )
231
- assert response.function_calls == [
232
- types.FunctionCall(
233
- name='get_weather',
234
- args={'location': 'Boston'},
235
- )
236
- ]
237
-
238
-
239
- def test_mcp_session_synchronous_call_raises_error(client):
240
- class MockMcpClientSession(McpClientSession):
241
-
242
- def __init__(self):
243
- self._read_stream = None
244
- self._write_stream = None
245
-
246
- async def list_tools(self):
247
- return mcp_types.ListToolsResult(
248
- tools=[
249
- mcp_types.Tool(
250
- name='get_weather',
251
- description='Get the weather in a city.',
252
- inputSchema={
253
- 'type': 'object',
254
- 'properties': {'location': {'type': 'string'}},
255
- },
256
- ),
257
- mcp_types.Tool(
258
- name='get_weather',
259
- description='Different tool to get the weather.',
260
- inputSchema={
261
- 'type': 'object',
262
- 'properties': {'location': {'type': 'string'}},
263
- },
264
- ),
265
- ]
266
- )
267
-
268
- with pytest.raises(errors.UnsupportedFunctionError):
269
- client.models.generate_content(
270
- model='gemini-2.5-flash',
271
- contents=t.t_contents('What is the weather in Boston?'),
272
- config={
273
- 'tools': [MockMcpClientSession()],
274
- },
275
- )
276
-
277
-
278
- def test_mcp_tools_synchronous_stream_call(client):
279
- response = client.models.generate_content_stream(
280
- model='gemini-2.5-flash',
281
- contents=t.t_contents('What is the weather in Boston?'),
282
- config={
283
- 'tools': [
284
- mcp_types.Tool(
285
- name='get_weather',
286
- description='Get the weather in a city.',
287
- inputSchema={
288
- 'type': 'object',
289
- 'properties': {'location': {'type': 'string'}},
290
- },
291
- )
292
- ]
293
- },
294
- )
295
- for chunk in response:
296
- assert chunk.function_calls == [
297
- types.FunctionCall(
298
- name='get_weather',
299
- args={'location': 'Boston'},
300
- )
301
- ]
302
-
303
-
304
- def test_mcp_session_synchronous_stream_call_raises_error(client):
305
- class MockMcpClientSession(McpClientSession):
306
-
307
- def __init__(self):
308
- self._read_stream = None
309
- self._write_stream = None
310
-
311
- async def list_tools(self):
312
- return mcp_types.ListToolsResult(
313
- tools=[
314
- mcp_types.Tool(
315
- name='get_weather',
316
- description='Get the weather in a city.',
317
- inputSchema={
318
- 'type': 'object',
319
- 'properties': {'location': {'type': 'string'}},
320
- },
321
- ),
322
- mcp_types.Tool(
323
- name='get_weather',
324
- description='Different tool to get the weather.',
325
- inputSchema={
326
- 'type': 'object',
327
- 'properties': {'location': {'type': 'string'}},
328
- },
329
- ),
330
- ]
331
- )
332
-
333
- response = client.models.generate_content_stream(
334
- model='gemini-2.5-flash',
335
- contents=t.t_contents('What is the weather in Boston?'),
336
- config={
337
- 'tools': [MockMcpClientSession()],
338
- },
339
- )
340
-
341
- with pytest.raises(errors.UnsupportedFunctionError):
342
- for chunk in response:
343
- pass
@@ -1,97 +0,0 @@
1
- # Copyright 2025 Google LLC
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
- #
15
-
16
-
17
- from ... import types
18
- from .. import pytest_helper
19
-
20
- test_table: list[pytest_helper.TestTableItem] = [
21
- pytest_helper.TestTableItem(
22
- name='test_video_audio_uri_with_media_resolution',
23
- parameters=types._GenerateContentParameters(
24
- model='gemini-2.5-flash',
25
- contents=[
26
- types.Content(
27
- role='user',
28
- parts=[
29
- types.Part.from_text(
30
- text=(
31
- 'Is the audio related to the video? '
32
- 'If so, how? '
33
- 'What are the common themes? '
34
- 'What are the different emphases?'
35
- )
36
- )
37
- ],
38
- ),
39
- types.Content(
40
- role='user',
41
- parts=[
42
- types.Part.from_uri(
43
- file_uri='gs://cloud-samples-data/generative-ai/video/pixel8.mp4',
44
- mime_type='video/mp4',
45
- )
46
- ],
47
- ),
48
- types.Content(
49
- role='user',
50
- parts=[
51
- types.Part.from_uri(
52
- file_uri='gs://cloud-samples-data/generative-ai/audio/pixel.mp3',
53
- mime_type='audio/mpeg',
54
- )
55
- ],
56
- ),
57
- ],
58
- config={
59
- 'system_instruction': types.Content(
60
- role='user',
61
- parts=[
62
- types.Part.from_text(
63
- text=(
64
- 'you are a helpful assistant for people with '
65
- 'visual and hearing disabilities.'
66
- )
67
- )
68
- ],
69
- ),
70
- 'media_resolution': 'MEDIA_RESOLUTION_LOW',
71
- },
72
- ),
73
- exception_if_mldev='400',
74
- )
75
- ]
76
-
77
-
78
- def test_low_media_resolution(client):
79
- with pytest_helper.exception_if_vertex(client, ValueError):
80
- file = client.files.upload(file='tests/data/google.png')
81
- response = client.models.generate_content(
82
- model='gemini-2.5-flash',
83
- contents=[file, 'Describe the image.'],
84
- config=types.GenerateContentConfig(
85
- media_resolution='MEDIA_RESOLUTION_LOW',
86
- http_options= types.HttpOptions(api_version='v1alpha', base_url='https://generativelanguage.googleapis.com')
87
- ),
88
- )
89
- assert response.text
90
-
91
-
92
- pytestmark = pytest_helper.setup(
93
- file=__file__,
94
- globals_for_file=globals(),
95
- test_method='models.generate_content',
96
- test_table=test_table,
97
- )
@@ -1,139 +0,0 @@
1
- # Copyright 2025 Google LLC
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
- #
15
-
16
-
17
- import pytest
18
-
19
- from ... import _transformers as t
20
- from ... import errors
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
- tuned_model_endpoint = (
25
- 'projects/801452371447/locations/us-central1/endpoints/4095574160837705728'
26
- )
27
-
28
-
29
- test_table: list[pytest_helper.TestTableItem] = [
30
- pytest_helper.TestTableItem(
31
- name='test_tuned_model',
32
- parameters=types._GenerateContentParameters(
33
- model=tuned_model_endpoint,
34
- contents=t.t_contents('Tell me a story in 300 words.'),
35
- ),
36
- exception_if_mldev='404',
37
- ),
38
- pytest_helper.TestTableItem(
39
- name='test_start_with_publishers',
40
- parameters=types._GenerateContentParameters(
41
- model='publishers/google/models/gemini-2.5-flash',
42
- contents=t.t_contents('Tell me a story in 50 words.'),
43
- ),
44
- exception_if_mldev='404',
45
- ),
46
- pytest_helper.TestTableItem(
47
- name='test_start_with_models',
48
- parameters=types._GenerateContentParameters(
49
- model='models/gemini-2.5-flash',
50
- contents=t.t_contents('Tell me a story in 50 words.'),
51
- ),
52
- exception_if_vertex='404',
53
- ),
54
- pytest_helper.TestTableItem(
55
- name='test_publisher_model',
56
- parameters=types._GenerateContentParameters(
57
- model='google/gemini-2.5-flash',
58
- contents=t.t_contents('Tell me a story in 50 words.'),
59
- ),
60
- exception_if_mldev='404',
61
- ),
62
- pytest_helper.TestTableItem(
63
- name='test_empty_model',
64
- parameters=types._GenerateContentParameters(
65
- model='',
66
- contents=t.t_contents('Tell me a story in 50 words.'),
67
- ),
68
- exception_if_mldev='model',
69
- exception_if_vertex='model',
70
- ),
71
- ]
72
-
73
- pytestmark = pytest_helper.setup(
74
- file=__file__,
75
- globals_for_file=globals(),
76
- test_method='models.generate_content',
77
- test_table=test_table,
78
- )
79
- pytest_plugins = ('pytest_asyncio',)
80
-
81
-
82
- def test_tuned_model_stream(client):
83
- # Vertex AI endpoints is not supported in MLDev.
84
- with pytest_helper.exception_if_mldev(client, errors.ClientError):
85
- chunks = 0
86
- for chunk in client.models.generate_content_stream(
87
- model=tuned_model_endpoint,
88
- contents='Tell me a story in 300 words.',
89
- ):
90
- chunks += 1
91
- assert chunk.text is not None or chunk.candidates[0].finish_reason
92
- assert chunks >= 2
93
-
94
-
95
- def test_start_with_models_stream(client):
96
- # vertex ai require publishers/ prefix for gemini
97
- with pytest_helper.exception_if_vertex(client, errors.ClientError):
98
- chunks = 0
99
- for chunk in client.models.generate_content_stream(
100
- model='models/gemini-2.5-flash',
101
- contents='Tell me a story in 50 words.',
102
- ):
103
- chunks += 1
104
- assert chunk.text is not None or chunk.candidates[0].finish_reason
105
- assert chunks >= 2
106
-
107
-
108
- def test_models_stream_with_non_empty_last_chunk(client):
109
- chunks = list(
110
- client.models.generate_content_stream(
111
- model='gemini-2.5-flash',
112
- contents='Tell me a story in 300 words.',
113
- )
114
- )
115
- assert chunks[-1].text
116
-
117
-
118
- @pytest.mark.asyncio
119
- async def test_start_with_models_stream_async(client):
120
- # vertex ai require publishers/ prefix for gemini
121
- with pytest_helper.exception_if_vertex(client, errors.ClientError):
122
- chunks = 0
123
- async for chunk in await client.aio.models.generate_content_stream(
124
- model='models/gemini-2.5-flash',
125
- contents='Tell me a story in 300 words.',
126
- ):
127
- chunks += 1
128
- assert chunk.text is not None or chunk.candidates[0].finish_reason
129
- assert chunks > 2
130
-
131
-
132
- @pytest.mark.asyncio
133
- async def test_start_with_models_async(client):
134
- # vertex ai require publishers/ prefix for gemini
135
- with pytest_helper.exception_if_vertex(client, errors.ClientError):
136
- await client.aio.models.generate_content(
137
- model='models/gemini-2.5-flash',
138
- contents='Tell me a story in 50 words.',
139
- )