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,94 +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
- # pylint: disable=protected-access
16
-
17
-
18
- """Tests for models.embedContent()."""
19
-
20
- import pytest
21
-
22
- from ... import _transformers as t
23
- from ... import types
24
- from .. import pytest_helper
25
-
26
-
27
- test_table: list[pytest_helper.TestTableItem] = [
28
- pytest_helper.TestTableItem(
29
- name='test_single_text',
30
- parameters=types._EmbedContentParameters(
31
- model='text-embedding-004',
32
- contents=t.t_contents('What is your name?'),
33
- ),
34
- ),
35
- pytest_helper.TestTableItem(
36
- name='test_multi_texts_with_config',
37
- parameters=types._EmbedContentParameters(
38
- model='text-embedding-004',
39
- contents=[
40
- t.t_content('What is your name?'),
41
- t.t_content('I am a model.'),
42
- ],
43
- config={
44
- 'output_dimensionality': 10,
45
- 'title': 'test_title',
46
- 'task_type': 'RETRIEVAL_DOCUMENT',
47
- 'http_options': {
48
- 'headers': {'test': 'headers'},
49
- },
50
- },
51
- ),
52
- ),
53
- pytest_helper.TestTableItem(
54
- name='test_single_text_with_mime_type_not_supported_in_mldev',
55
- parameters=types._EmbedContentParameters(
56
- model='text-embedding-004',
57
- contents=t.t_contents('What is your name?'),
58
- config={
59
- 'output_dimensionality': 10,
60
- 'mime_type': 'text/plain',
61
- },
62
- ),
63
- exception_if_mldev='parameter is not supported',
64
- ),
65
- pytest_helper.TestTableItem(
66
- name='test_single_text_with_auto_truncate_not_supported_in_mldev',
67
- parameters=types._EmbedContentParameters(
68
- model='text-embedding-004',
69
- contents=t.t_contents('What is your name?'),
70
- config={
71
- 'output_dimensionality': 10,
72
- 'auto_truncate': True,
73
- },
74
- ),
75
- exception_if_mldev='parameter is not supported',
76
- ),
77
- ]
78
-
79
- pytestmark = pytest_helper.setup(
80
- file=__file__,
81
- globals_for_file=globals(),
82
- test_method='models.embed_content',
83
- test_table=test_table,
84
- )
85
-
86
-
87
- @pytest.mark.asyncio
88
- async def test_async(client):
89
- response = await client.aio.models.embed_content(
90
- model='text-embedding-004',
91
- contents='What is your name?',
92
- config={'output_dimensionality': 10},
93
- )
94
- assert response
@@ -1,442 +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
- """Tests for models.generate_content_stream() with stream_function_call_arguments enabled."""
17
-
18
- import pytest
19
- from ... import types
20
- from unittest import mock
21
- from .. import pytest_helper
22
- from . import test_generate_content_tools
23
-
24
- json_function_declarations = [{
25
- 'name': 'get_current_weather',
26
- 'description': 'Get the current weather in a city',
27
- 'parameters_json_schema': {
28
- 'type': 'object',
29
- 'properties': {
30
- 'location': {
31
- 'type': 'string',
32
- 'description': 'The location to get the weather for',
33
- },
34
- 'country': {
35
- 'anyOf': [
36
- {
37
- 'type': 'string',
38
- 'description': 'The country to get the weather for',
39
- },
40
- {
41
- 'type': 'null',
42
- },
43
- ],
44
- 'description': 'The country to get the weather for',
45
- },
46
- 'unit': {
47
- 'type': 'string',
48
- 'enum': ['C', 'F'],
49
- },
50
- 'purpose': {
51
- 'type': 'string',
52
- 'description': 'Discribes the purpose of asking the weather',
53
- }
54
- },
55
- 'required': ['location', 'unit', 'country'],
56
- },
57
- }]
58
-
59
- gemini_function_declarations = [{
60
- 'name': 'get_current_weather',
61
- 'description': 'Get the current weather in a city',
62
- 'parameters': {
63
- 'type': 'OBJECT',
64
- 'properties': {
65
- 'location': {
66
- 'type': 'STRING',
67
- 'description': 'The location to get the weather for',
68
- },
69
- 'country': {
70
- 'type': 'STRING',
71
- 'description': 'The country to get the weather for',
72
- 'nullable': True,
73
- },
74
- 'unit': {
75
- 'type': 'STRING',
76
- 'enum': ['C', 'F'],
77
- 'description': 'The unit to return the weather in',
78
- },
79
- 'purpose': {
80
- 'type': 'STRING',
81
- 'description': 'Discribes the purpose of asking the weather',
82
- }
83
- },
84
- 'required': ['location', 'unit', 'country'],
85
- },
86
- }]
87
-
88
- generate_content_prompt = [
89
- types.Content(
90
- role='user',
91
- parts=[
92
- types.Part(
93
- text=(
94
- 'get the current weather in boston in celsius, the'
95
- ' country should be US, the purpose is to know'
96
- ' what to wear today?'
97
- )
98
- )
99
- ],
100
- ),
101
- ]
102
- previous_generate_content_history = [
103
- types.Content(
104
- role='user',
105
- parts=[
106
- types.Part(
107
- text=(
108
- ' get the current weather in boston in celsius, the country'
109
- ' is U.S., the purpose is to'
110
- ' know what to wear today.'
111
- )
112
- )
113
- ],
114
- ),
115
- types.Content(
116
- role='model',
117
- parts=[
118
- types.Part(
119
- function_call=types.FunctionCall(
120
- name='get_current_weather',
121
- will_continue=True,
122
- )
123
- )
124
- ],
125
- ),
126
- types.Content(
127
- role='model',
128
- parts=[
129
- types.Part(
130
- function_call=types.FunctionCall(
131
- name='get_current_weather',
132
- partial_args=[
133
- types.PartialArg(
134
- json_path='$.country',
135
- null_value="NULL_VALUE",
136
- )
137
- ],
138
- will_continue=False,
139
- )
140
- )
141
- ],
142
- )
143
- ]
144
-
145
- pytestmark = pytest_helper.setup(
146
- file=__file__,
147
- globals_for_file=globals(),
148
- test_method='models.generate_content_stream',
149
- )
150
-
151
- def test_streaming_with_python_native_no_afc_config(client):
152
- """Tests streaming function calls with native python AFC without disabling AFC."""
153
- if not client.vertexai:
154
- return
155
- with pytest.raises(ValueError) as e:
156
- for chunk in client.models.generate_content_stream(
157
- model='gemini-2.5-pro',
158
- contents=generate_content_prompt,
159
- config=types.GenerateContentConfig(
160
- tools=[
161
- test_generate_content_tools.get_weather,
162
- test_generate_content_tools.get_stock_price,
163
- ],
164
- tool_config=types.ToolConfig(
165
- function_calling_config={
166
- 'stream_function_call_arguments': True,
167
- }
168
- ),
169
- ),
170
- ):
171
- pass
172
-
173
- assert 'not compatible with automatic function calling (AFC)' in str(e.value)
174
-
175
-
176
- def test_streaming_with_python_afc_disabled_false(client):
177
- """Tests streaming function calls with native python AFC without disabling AFC."""
178
- if not client.vertexai:
179
- return
180
- with pytest.raises(ValueError) as e:
181
- for chunk in client.models.generate_content_stream(
182
- model='gemini-2.5-pro',
183
- contents='What is the price of GOOG? And what is the weather in Boston?',
184
- config=types.GenerateContentConfig(
185
- tools=[
186
- test_generate_content_tools.get_weather,
187
- test_generate_content_tools.get_stock_price,
188
- ],
189
- automatic_function_calling=types.AutomaticFunctionCallingConfig(
190
- disable=False,
191
- ),
192
- tool_config=types.ToolConfig(
193
- function_calling_config={
194
- 'stream_function_call_arguments': True,
195
- }
196
- ),
197
- ),
198
- ):
199
- pass
200
- assert 'not compatible with automatic function calling (AFC)' in str(e.value)
201
-
202
-
203
- def test_streaming_with_json_parameters_without_history(client):
204
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
205
-
206
- with pytest_helper.exception_if_mldev(client, ValueError):
207
- for chunk in client.models.generate_content_stream(
208
- model='gemini-2.5-pro',
209
- contents=generate_content_prompt,
210
- config=types.GenerateContentConfig(
211
- tools=[{'function_declarations': json_function_declarations}],
212
- tool_config=types.ToolConfig(
213
- function_calling_config={
214
- 'stream_function_call_arguments': True,
215
- }
216
- ),
217
- ),
218
- ):
219
- assert chunk is not None
220
- assert chunk.candidates is not None
221
- assert chunk.candidates[0].content is not None
222
- assert chunk.candidates[0].content.parts is not None
223
-
224
-
225
- def test_streaming_with_json_parameters_with_history(client):
226
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
227
- with pytest_helper.exception_if_mldev(client, ValueError):
228
- for chunk in client.models.generate_content_stream(
229
- model='gemini-2.5-pro',
230
- contents=previous_generate_content_history,
231
- config=types.GenerateContentConfig(
232
- tools=[{'function_declarations': json_function_declarations}],
233
- tool_config=types.ToolConfig(
234
- function_calling_config={
235
- 'stream_function_call_arguments': True,
236
- }
237
- ),
238
- ),
239
- ):
240
- assert chunk is not None
241
- assert chunk.candidates is not None
242
- assert chunk.candidates[0].content is not None
243
- assert chunk.candidates[0].content.parts is not None
244
-
245
- @pytest.mark.asyncio
246
- async def test_streaming_with_json_parameters_async(client):
247
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
248
- with pytest_helper.exception_if_mldev(client, ValueError):
249
- async for chunk in await client.aio.models.generate_content_stream(
250
- model='gemini-2.5-pro',
251
- contents=generate_content_prompt,
252
- config=types.GenerateContentConfig(
253
- tools=[{'function_declarations': json_function_declarations}],
254
- tool_config=types.ToolConfig(
255
- function_calling_config={
256
- 'stream_function_call_arguments': True,
257
- }
258
- ),
259
- ),
260
- ):
261
- assert chunk is not None
262
- assert chunk.candidates is not None
263
- assert chunk.candidates[0].content is not None
264
- assert chunk.candidates[0].content.parts is not None
265
-
266
-
267
- def test_streaming_with_gemini_parameters_without_history(client):
268
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
269
- with pytest_helper.exception_if_mldev(client, ValueError):
270
- for chunk in client.models.generate_content_stream(
271
- model='gemini-2.5-pro',
272
- contents=generate_content_prompt,
273
- config=types.GenerateContentConfig(
274
- tools=[{
275
- 'function_declarations': gemini_function_declarations
276
- }],
277
- tool_config=types.ToolConfig(
278
- function_calling_config={
279
- 'stream_function_call_arguments': True,
280
- }
281
- ),
282
- ),
283
- ):
284
- assert chunk is not None
285
- assert chunk.candidates is not None
286
- assert chunk.candidates[0].content is not None
287
- assert chunk.candidates[0].content.parts is not None
288
-
289
- def test_streaming_with_gemini_parameters_with_response(client):
290
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
291
- with pytest_helper.exception_if_mldev(client, ValueError):
292
- streaming_function_call_content = []
293
- for chunk in client.models.generate_content_stream(
294
- model='gemini-2.5-pro',
295
- contents=[
296
- types.Content(
297
- role='user',
298
- parts=[
299
- types.Part(
300
- text=(
301
- 'get the current weather in boston in celsius, the'
302
- ' country should be US, the purpose is to know'
303
- ' what to wear today?'
304
- )
305
- )
306
- ],
307
- ),
308
- ],
309
- config=types.GenerateContentConfig(
310
- tools=[{
311
- 'function_declarations': gemini_function_declarations
312
- }],
313
- tool_config=types.ToolConfig(
314
- function_calling_config={
315
- 'stream_function_call_arguments': True,
316
- }
317
- ),
318
- ),
319
- ):
320
- streaming_function_call_content.append(chunk.candidates[0].content)
321
-
322
- streaming_function_call_content.append(
323
- types.Content(
324
- role='user',
325
- parts=[
326
- types.Part.from_function_response(
327
- name='get_current_weather',
328
- response={
329
- 'temperature': 21,
330
- 'unit': 'C',
331
- },
332
- )
333
- ],
334
- ),
335
- )
336
-
337
- for chunk in client.models.generate_content_stream(
338
- model='gemini-2.5-pro',
339
- contents=streaming_function_call_content,
340
- config=types.GenerateContentConfig(
341
- tools=[{'function_declarations': json_function_declarations}],
342
- tool_config=types.ToolConfig(
343
- function_calling_config={
344
- 'stream_function_call_arguments': True,
345
- }
346
- ),
347
- ),
348
- ):
349
- pass
350
-
351
- def test_streaming_with_gemini_parameters_with_history(client):
352
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
353
- with pytest_helper.exception_if_mldev(client, ValueError):
354
- for chunk in client.models.generate_content_stream(
355
- model='gemini-2.5-pro',
356
- contents=previous_generate_content_history,
357
- config=types.GenerateContentConfig(
358
- tools=[{
359
- 'function_declarations': gemini_function_declarations
360
- }],
361
- tool_config=types.ToolConfig(
362
- function_calling_config={
363
- 'stream_function_call_arguments': True,
364
- }
365
- ),
366
- ),
367
- ):
368
- assert chunk is not None
369
- assert chunk.candidates is not None
370
- assert chunk.candidates[0].content is not None
371
- assert chunk.candidates[0].content.parts is not None
372
-
373
- def test_chat_streaming_with_json_parameters_with_history(client):
374
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
375
- with pytest_helper.exception_if_mldev(client, ValueError):
376
- messages = [
377
- """
378
- get the current weather in boston in celsius, the country is U.S., the purpose is to know what to wear today.
379
- """,
380
- """
381
- get the current weather in new brunswick in celsius, the country is U.S., the purpose is to know what to prepare an event today.
382
- """,
383
- ]
384
- chat = client.chats.create(
385
- model='gemini-2.5-pro',
386
- history=previous_generate_content_history,
387
- config=types.GenerateContentConfig(
388
- tools=[{
389
- 'function_declarations': gemini_function_declarations
390
- }],
391
- tool_config=types.ToolConfig(
392
- function_calling_config={
393
- 'stream_function_call_arguments': True,
394
- }
395
- ),
396
- ),
397
- )
398
- for message in messages:
399
- result = chat.send_message_stream(message)
400
- for chunk in result:
401
- assert chunk is not None
402
- assert chunk.candidates is not None
403
- assert chunk.candidates[0].content is not None
404
- assert chunk.candidates[0].content.parts is not None
405
-
406
- assert chat.get_history() is not None
407
-
408
-
409
- @pytest.mark.asyncio
410
- async def test_chat_streaming_with_json_parameters_with_history_async(client):
411
- """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
412
- messages = [
413
- """
414
- get the current weather in boston in celsius, the country is U.S., the purpose is to know what to wear today.
415
- """,
416
- """
417
- get the current weather in new brunswick in celsius, the country is U.S., the purpose is to know what to prepare an event today.
418
- """,
419
- ]
420
- with pytest_helper.exception_if_mldev(client, ValueError):
421
- chat = client.aio.chats.create(
422
- model='gemini-2.5-pro',
423
- history=previous_generate_content_history,
424
- config=types.GenerateContentConfig(
425
- tools=[{'function_declarations': gemini_function_declarations}],
426
- tool_config=types.ToolConfig(
427
- function_calling_config={
428
- 'stream_function_call_arguments': True,
429
- }
430
- ),
431
- ),
432
- )
433
- async for chunk in await chat.send_message_stream(messages[0]):
434
- assert chunk is not None
435
- assert chunk.candidates is not None
436
- assert chunk.candidates[0].content is not None
437
- assert chunk.candidates[0].content.parts is not None
438
- async for chunk in await chat.send_message_stream(messages[1]):
439
- assert chunk is not None
440
- assert chunk.candidates is not None
441
- assert chunk.candidates[0].content is not None
442
- assert chunk.candidates[0].content.parts is not None