google-genai 1.56.0__py3-none-any.whl → 1.58.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 (246) hide show
  1. google/genai/_api_client.py +49 -26
  2. google/genai/_interactions/__init__.py +3 -0
  3. google/genai/_interactions/_base_client.py +1 -1
  4. google/genai/_interactions/_client.py +57 -3
  5. google/genai/_interactions/_client_adapter.py +48 -0
  6. google/genai/_interactions/types/__init__.py +6 -0
  7. google/genai/_interactions/types/audio_content.py +2 -0
  8. google/genai/_interactions/types/audio_content_param.py +2 -0
  9. google/genai/_interactions/types/content.py +65 -0
  10. google/genai/_interactions/types/content_delta.py +10 -2
  11. google/genai/_interactions/types/content_param.py +63 -0
  12. google/genai/_interactions/types/content_start.py +5 -46
  13. google/genai/_interactions/types/content_stop.py +1 -2
  14. google/genai/_interactions/types/document_content.py +2 -0
  15. google/genai/_interactions/types/document_content_param.py +2 -0
  16. google/genai/_interactions/types/error_event.py +1 -2
  17. google/genai/_interactions/types/file_search_call_content.py +32 -0
  18. google/genai/_interactions/types/file_search_call_content_param.py +31 -0
  19. google/genai/_interactions/types/generation_config.py +4 -0
  20. google/genai/_interactions/types/generation_config_param.py +4 -0
  21. google/genai/_interactions/types/image_config.py +31 -0
  22. google/genai/_interactions/types/image_config_param.py +30 -0
  23. google/genai/_interactions/types/image_content.py +2 -0
  24. google/genai/_interactions/types/image_content_param.py +2 -0
  25. google/genai/_interactions/types/interaction.py +6 -52
  26. google/genai/_interactions/types/interaction_create_params.py +4 -22
  27. google/genai/_interactions/types/interaction_event.py +1 -2
  28. google/genai/_interactions/types/interaction_sse_event.py +5 -3
  29. google/genai/_interactions/types/interaction_status_update.py +1 -2
  30. google/genai/_interactions/types/model.py +1 -0
  31. google/genai/_interactions/types/model_param.py +1 -0
  32. google/genai/_interactions/types/turn.py +3 -44
  33. google/genai/_interactions/types/turn_param.py +4 -40
  34. google/genai/_interactions/types/usage.py +1 -1
  35. google/genai/_interactions/types/usage_param.py +1 -1
  36. google/genai/_interactions/types/video_content.py +2 -0
  37. google/genai/_interactions/types/video_content_param.py +2 -0
  38. google/genai/_live_converters.py +118 -34
  39. google/genai/_local_tokenizer_loader.py +1 -0
  40. google/genai/_tokens_converters.py +14 -14
  41. google/genai/_transformers.py +15 -21
  42. google/genai/batches.py +27 -22
  43. google/genai/caches.py +42 -42
  44. google/genai/chats.py +0 -2
  45. google/genai/client.py +61 -55
  46. google/genai/files.py +224 -0
  47. google/genai/live.py +1 -1
  48. google/genai/models.py +56 -44
  49. google/genai/tests/__init__.py +21 -0
  50. google/genai/tests/afc/__init__.py +21 -0
  51. google/genai/tests/afc/test_convert_if_exist_pydantic_model.py +309 -0
  52. google/genai/tests/afc/test_convert_number_values_for_function_call_args.py +63 -0
  53. google/genai/tests/afc/test_find_afc_incompatible_tool_indexes.py +240 -0
  54. google/genai/tests/afc/test_generate_content_stream_afc.py +530 -0
  55. google/genai/tests/afc/test_generate_content_stream_afc_thoughts.py +77 -0
  56. google/genai/tests/afc/test_get_function_map.py +176 -0
  57. google/genai/tests/afc/test_get_function_response_parts.py +277 -0
  58. google/genai/tests/afc/test_get_max_remote_calls_for_afc.py +130 -0
  59. google/genai/tests/afc/test_invoke_function_from_dict_args.py +241 -0
  60. google/genai/tests/afc/test_raise_error_for_afc_incompatible_config.py +159 -0
  61. google/genai/tests/afc/test_should_append_afc_history.py +53 -0
  62. google/genai/tests/afc/test_should_disable_afc.py +214 -0
  63. google/genai/tests/batches/__init__.py +17 -0
  64. google/genai/tests/batches/test_cancel.py +77 -0
  65. google/genai/tests/batches/test_create.py +78 -0
  66. google/genai/tests/batches/test_create_with_bigquery.py +113 -0
  67. google/genai/tests/batches/test_create_with_file.py +82 -0
  68. google/genai/tests/batches/test_create_with_gcs.py +125 -0
  69. google/genai/tests/batches/test_create_with_inlined_requests.py +255 -0
  70. google/genai/tests/batches/test_delete.py +86 -0
  71. google/genai/tests/batches/test_embedding.py +157 -0
  72. google/genai/tests/batches/test_get.py +78 -0
  73. google/genai/tests/batches/test_list.py +79 -0
  74. google/genai/tests/caches/__init__.py +17 -0
  75. google/genai/tests/caches/constants.py +29 -0
  76. google/genai/tests/caches/test_create.py +210 -0
  77. google/genai/tests/caches/test_create_custom_url.py +105 -0
  78. google/genai/tests/caches/test_delete.py +54 -0
  79. google/genai/tests/caches/test_delete_custom_url.py +52 -0
  80. google/genai/tests/caches/test_get.py +94 -0
  81. google/genai/tests/caches/test_get_custom_url.py +52 -0
  82. google/genai/tests/caches/test_list.py +68 -0
  83. google/genai/tests/caches/test_update.py +70 -0
  84. google/genai/tests/caches/test_update_custom_url.py +58 -0
  85. google/genai/tests/chats/__init__.py +1 -0
  86. google/genai/tests/chats/test_get_history.py +598 -0
  87. google/genai/tests/chats/test_send_message.py +844 -0
  88. google/genai/tests/chats/test_validate_response.py +90 -0
  89. google/genai/tests/client/__init__.py +17 -0
  90. google/genai/tests/client/test_async_stream.py +427 -0
  91. google/genai/tests/client/test_client_close.py +197 -0
  92. google/genai/tests/client/test_client_initialization.py +1687 -0
  93. google/genai/tests/client/test_client_requests.py +221 -0
  94. google/genai/tests/client/test_custom_client.py +104 -0
  95. google/genai/tests/client/test_http_options.py +178 -0
  96. google/genai/tests/client/test_replay_client_equality.py +168 -0
  97. google/genai/tests/client/test_retries.py +846 -0
  98. google/genai/tests/client/test_upload_errors.py +136 -0
  99. google/genai/tests/common/__init__.py +17 -0
  100. google/genai/tests/common/test_common.py +954 -0
  101. google/genai/tests/conftest.py +162 -0
  102. google/genai/tests/documents/__init__.py +17 -0
  103. google/genai/tests/documents/test_delete.py +51 -0
  104. google/genai/tests/documents/test_get.py +85 -0
  105. google/genai/tests/documents/test_list.py +72 -0
  106. google/genai/tests/errors/__init__.py +1 -0
  107. google/genai/tests/errors/test_api_error.py +417 -0
  108. google/genai/tests/file_search_stores/__init__.py +17 -0
  109. google/genai/tests/file_search_stores/test_create.py +66 -0
  110. google/genai/tests/file_search_stores/test_delete.py +64 -0
  111. google/genai/tests/file_search_stores/test_get.py +94 -0
  112. google/genai/tests/file_search_stores/test_import_file.py +112 -0
  113. google/genai/tests/file_search_stores/test_list.py +57 -0
  114. google/genai/tests/file_search_stores/test_upload_to_file_search_store.py +141 -0
  115. google/genai/tests/files/__init__.py +17 -0
  116. google/genai/tests/files/test_delete.py +46 -0
  117. google/genai/tests/files/test_download.py +85 -0
  118. google/genai/tests/files/test_get.py +46 -0
  119. google/genai/tests/files/test_list.py +72 -0
  120. google/genai/tests/files/test_register.py +272 -0
  121. google/genai/tests/files/test_register_table.py +70 -0
  122. google/genai/tests/files/test_upload.py +255 -0
  123. google/genai/tests/imports/test_no_optional_imports.py +28 -0
  124. google/genai/tests/interactions/test_auth.py +476 -0
  125. google/genai/tests/interactions/test_integration.py +84 -0
  126. google/genai/tests/interactions/test_paths.py +105 -0
  127. google/genai/tests/live/__init__.py +16 -0
  128. google/genai/tests/live/test_live.py +2143 -0
  129. google/genai/tests/live/test_live_music.py +362 -0
  130. google/genai/tests/live/test_live_response.py +163 -0
  131. google/genai/tests/live/test_send_client_content.py +147 -0
  132. google/genai/tests/live/test_send_realtime_input.py +268 -0
  133. google/genai/tests/live/test_send_tool_response.py +222 -0
  134. google/genai/tests/local_tokenizer/__init__.py +17 -0
  135. google/genai/tests/local_tokenizer/test_local_tokenizer.py +343 -0
  136. google/genai/tests/local_tokenizer/test_local_tokenizer_loader.py +235 -0
  137. google/genai/tests/mcp/__init__.py +17 -0
  138. google/genai/tests/mcp/test_has_mcp_tool_usage.py +89 -0
  139. google/genai/tests/mcp/test_mcp_to_gemini_tools.py +191 -0
  140. google/genai/tests/mcp/test_parse_config_for_mcp_sessions.py +201 -0
  141. google/genai/tests/mcp/test_parse_config_for_mcp_usage.py +130 -0
  142. google/genai/tests/mcp/test_set_mcp_usage_header.py +72 -0
  143. google/genai/tests/models/__init__.py +17 -0
  144. google/genai/tests/models/constants.py +8 -0
  145. google/genai/tests/models/test_compute_tokens.py +120 -0
  146. google/genai/tests/models/test_count_tokens.py +159 -0
  147. google/genai/tests/models/test_delete.py +107 -0
  148. google/genai/tests/models/test_edit_image.py +264 -0
  149. google/genai/tests/models/test_embed_content.py +94 -0
  150. google/genai/tests/models/test_function_call_streaming.py +442 -0
  151. google/genai/tests/models/test_generate_content.py +2501 -0
  152. google/genai/tests/models/test_generate_content_cached_content.py +132 -0
  153. google/genai/tests/models/test_generate_content_config_zero_value.py +103 -0
  154. google/genai/tests/models/test_generate_content_from_apikey.py +44 -0
  155. google/genai/tests/models/test_generate_content_http_options.py +40 -0
  156. google/genai/tests/models/test_generate_content_image_generation.py +143 -0
  157. google/genai/tests/models/test_generate_content_mcp.py +343 -0
  158. google/genai/tests/models/test_generate_content_media_resolution.py +97 -0
  159. google/genai/tests/models/test_generate_content_model.py +139 -0
  160. google/genai/tests/models/test_generate_content_part.py +821 -0
  161. google/genai/tests/models/test_generate_content_thought.py +76 -0
  162. google/genai/tests/models/test_generate_content_tools.py +1761 -0
  163. google/genai/tests/models/test_generate_images.py +191 -0
  164. google/genai/tests/models/test_generate_videos.py +759 -0
  165. google/genai/tests/models/test_get.py +104 -0
  166. google/genai/tests/models/test_list.py +233 -0
  167. google/genai/tests/models/test_recontext_image.py +189 -0
  168. google/genai/tests/models/test_segment_image.py +148 -0
  169. google/genai/tests/models/test_update.py +95 -0
  170. google/genai/tests/models/test_upscale_image.py +157 -0
  171. google/genai/tests/operations/__init__.py +17 -0
  172. google/genai/tests/operations/test_get.py +38 -0
  173. google/genai/tests/public_samples/__init__.py +17 -0
  174. google/genai/tests/public_samples/test_gemini_text_only.py +34 -0
  175. google/genai/tests/pytest_helper.py +246 -0
  176. google/genai/tests/shared/__init__.py +16 -0
  177. google/genai/tests/shared/batches/__init__.py +14 -0
  178. google/genai/tests/shared/batches/test_create_delete.py +57 -0
  179. google/genai/tests/shared/batches/test_create_get_cancel.py +56 -0
  180. google/genai/tests/shared/batches/test_list.py +40 -0
  181. google/genai/tests/shared/caches/__init__.py +14 -0
  182. google/genai/tests/shared/caches/test_create_get_delete.py +67 -0
  183. google/genai/tests/shared/caches/test_create_update_get.py +71 -0
  184. google/genai/tests/shared/caches/test_list.py +40 -0
  185. google/genai/tests/shared/chats/__init__.py +14 -0
  186. google/genai/tests/shared/chats/test_send_message.py +48 -0
  187. google/genai/tests/shared/chats/test_send_message_stream.py +50 -0
  188. google/genai/tests/shared/files/__init__.py +14 -0
  189. google/genai/tests/shared/files/test_list.py +41 -0
  190. google/genai/tests/shared/files/test_upload_get_delete.py +54 -0
  191. google/genai/tests/shared/models/__init__.py +14 -0
  192. google/genai/tests/shared/models/test_compute_tokens.py +41 -0
  193. google/genai/tests/shared/models/test_count_tokens.py +40 -0
  194. google/genai/tests/shared/models/test_edit_image.py +67 -0
  195. google/genai/tests/shared/models/test_embed.py +40 -0
  196. google/genai/tests/shared/models/test_generate_content.py +39 -0
  197. google/genai/tests/shared/models/test_generate_content_stream.py +54 -0
  198. google/genai/tests/shared/models/test_generate_images.py +40 -0
  199. google/genai/tests/shared/models/test_generate_videos.py +38 -0
  200. google/genai/tests/shared/models/test_list.py +37 -0
  201. google/genai/tests/shared/models/test_recontext_image.py +55 -0
  202. google/genai/tests/shared/models/test_segment_image.py +52 -0
  203. google/genai/tests/shared/models/test_upscale_image.py +52 -0
  204. google/genai/tests/shared/tunings/__init__.py +16 -0
  205. google/genai/tests/shared/tunings/test_create.py +46 -0
  206. google/genai/tests/shared/tunings/test_create_get_cancel.py +56 -0
  207. google/genai/tests/shared/tunings/test_list.py +39 -0
  208. google/genai/tests/tokens/__init__.py +16 -0
  209. google/genai/tests/tokens/test_create.py +154 -0
  210. google/genai/tests/transformers/__init__.py +17 -0
  211. google/genai/tests/transformers/test_blobs.py +84 -0
  212. google/genai/tests/transformers/test_bytes.py +15 -0
  213. google/genai/tests/transformers/test_duck_type.py +96 -0
  214. google/genai/tests/transformers/test_function_responses.py +72 -0
  215. google/genai/tests/transformers/test_schema.py +653 -0
  216. google/genai/tests/transformers/test_t_batch.py +286 -0
  217. google/genai/tests/transformers/test_t_content.py +160 -0
  218. google/genai/tests/transformers/test_t_contents.py +398 -0
  219. google/genai/tests/transformers/test_t_part.py +85 -0
  220. google/genai/tests/transformers/test_t_parts.py +87 -0
  221. google/genai/tests/transformers/test_t_tool.py +157 -0
  222. google/genai/tests/transformers/test_t_tools.py +195 -0
  223. google/genai/tests/tunings/__init__.py +16 -0
  224. google/genai/tests/tunings/test_cancel.py +39 -0
  225. google/genai/tests/tunings/test_end_to_end.py +106 -0
  226. google/genai/tests/tunings/test_get.py +67 -0
  227. google/genai/tests/tunings/test_list.py +75 -0
  228. google/genai/tests/tunings/test_tune.py +268 -0
  229. google/genai/tests/types/__init__.py +16 -0
  230. google/genai/tests/types/test_bytes_internal.py +271 -0
  231. google/genai/tests/types/test_bytes_type.py +152 -0
  232. google/genai/tests/types/test_future.py +101 -0
  233. google/genai/tests/types/test_optional_types.py +36 -0
  234. google/genai/tests/types/test_part_type.py +616 -0
  235. google/genai/tests/types/test_schema_from_json_schema.py +417 -0
  236. google/genai/tests/types/test_schema_json_schema.py +468 -0
  237. google/genai/tests/types/test_types.py +2903 -0
  238. google/genai/types.py +631 -488
  239. google/genai/version.py +1 -1
  240. {google_genai-1.56.0.dist-info → google_genai-1.58.0.dist-info}/METADATA +6 -11
  241. google_genai-1.58.0.dist-info/RECORD +358 -0
  242. google_genai-1.56.0.dist-info/RECORD +0 -162
  243. /google/genai/{_interactions/py.typed → tests/interactions/__init__.py} +0 -0
  244. {google_genai-1.56.0.dist-info → google_genai-1.58.0.dist-info}/WHEEL +0 -0
  245. {google_genai-1.56.0.dist-info → google_genai-1.58.0.dist-info}/licenses/LICENSE +0 -0
  246. {google_genai-1.56.0.dist-info → google_genai-1.58.0.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,94 @@
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
@@ -0,0 +1,442 @@
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-3-pro-preview',
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-3-pro-preview',
183
+ contents=(
184
+ 'What is the price of GOOG? And what is the weather in Boston?'
185
+ ),
186
+ config=types.GenerateContentConfig(
187
+ tools=[
188
+ test_generate_content_tools.get_weather,
189
+ test_generate_content_tools.get_stock_price,
190
+ ],
191
+ automatic_function_calling=types.AutomaticFunctionCallingConfig(
192
+ disable=False,
193
+ ),
194
+ tool_config=types.ToolConfig(
195
+ function_calling_config={
196
+ 'stream_function_call_arguments': True,
197
+ }
198
+ ),
199
+ ),
200
+ ):
201
+ pass
202
+ assert 'not compatible with automatic function calling (AFC)' in str(e.value)
203
+
204
+
205
+ def test_streaming_with_json_parameters_without_history(client):
206
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
207
+
208
+ with pytest_helper.exception_if_mldev(client, ValueError):
209
+ for chunk in client.models.generate_content_stream(
210
+ model='gemini-3-pro-preview',
211
+ contents=generate_content_prompt,
212
+ config=types.GenerateContentConfig(
213
+ tools=[{'function_declarations': json_function_declarations}],
214
+ tool_config=types.ToolConfig(
215
+ function_calling_config={
216
+ 'stream_function_call_arguments': True,
217
+ }
218
+ ),
219
+ ),
220
+ ):
221
+ assert chunk is not None
222
+ assert chunk.candidates is not None
223
+ assert chunk.candidates[0].content is not None
224
+ assert chunk.candidates[0].content.parts is not None
225
+
226
+
227
+ @pytest.mark.asyncio
228
+ async def test_streaming_with_json_parameters_async(client):
229
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
230
+ with pytest_helper.exception_if_mldev(client, ValueError):
231
+ async for chunk in await client.aio.models.generate_content_stream(
232
+ model='gemini-3-pro-preview',
233
+ contents=generate_content_prompt,
234
+ config=types.GenerateContentConfig(
235
+ tools=[{'function_declarations': json_function_declarations}],
236
+ tool_config=types.ToolConfig(
237
+ function_calling_config={
238
+ 'stream_function_call_arguments': True,
239
+ }
240
+ ),
241
+ ),
242
+ ):
243
+ assert chunk is not None
244
+ assert chunk.candidates is not None
245
+ assert chunk.candidates[0].content is not None
246
+ assert chunk.candidates[0].content.parts is not None
247
+
248
+
249
+ def test_streaming_with_gemini_parameters_without_history(client):
250
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
251
+ with pytest_helper.exception_if_mldev(client, ValueError):
252
+ for chunk in client.models.generate_content_stream(
253
+ model='gemini-3-pro-preview',
254
+ contents=generate_content_prompt,
255
+ config=types.GenerateContentConfig(
256
+ tools=[{
257
+ 'function_declarations': gemini_function_declarations
258
+ }],
259
+ tool_config=types.ToolConfig(
260
+ function_calling_config={
261
+ 'stream_function_call_arguments': True,
262
+ }
263
+ ),
264
+ ),
265
+ ):
266
+ assert chunk is not None
267
+ assert chunk.candidates is not None
268
+ assert chunk.candidates[0].content is not None
269
+ assert chunk.candidates[0].content.parts is not None
270
+
271
+ def test_streaming_with_gemini_parameters_with_response(client):
272
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
273
+ with pytest_helper.exception_if_mldev(client, ValueError):
274
+ streaming_function_call_content = []
275
+ for chunk in client.models.generate_content_stream(
276
+ model='gemini-3-pro-preview',
277
+ contents=[
278
+ types.Content(
279
+ role='user',
280
+ parts=[
281
+ types.Part(
282
+ text=(
283
+ 'get the current weather in boston in celsius, the'
284
+ ' country should be US, the purpose is to know'
285
+ ' what to wear today?'
286
+ )
287
+ )
288
+ ],
289
+ ),
290
+ ],
291
+ config=types.GenerateContentConfig(
292
+ tools=[{
293
+ 'function_declarations': gemini_function_declarations
294
+ }],
295
+ tool_config=types.ToolConfig(
296
+ function_calling_config={
297
+ 'stream_function_call_arguments': True,
298
+ }
299
+ ),
300
+ ),
301
+ ):
302
+ streaming_function_call_content.append(chunk.candidates[0].content)
303
+
304
+ streaming_function_call_content.append(
305
+ types.Content(
306
+ role='user',
307
+ parts=[
308
+ types.Part.from_function_response(
309
+ name='get_current_weather',
310
+ response={
311
+ 'temperature': 21,
312
+ 'unit': 'C',
313
+ },
314
+ )
315
+ ],
316
+ ),
317
+ )
318
+
319
+ for chunk in client.models.generate_content_stream(
320
+ model='gemini-3-pro-preview',
321
+ contents=streaming_function_call_content,
322
+ config=types.GenerateContentConfig(
323
+ tools=[{'function_declarations': json_function_declarations}],
324
+ tool_config=types.ToolConfig(
325
+ function_calling_config={
326
+ 'stream_function_call_arguments': True,
327
+ }
328
+ ),
329
+ ),
330
+ ):
331
+ pass
332
+
333
+ def test_chat_streaming_with_json_parameters_with_history(client):
334
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
335
+ with pytest_helper.exception_if_mldev(client, ValueError):
336
+ test_parts = [
337
+ types.Part(
338
+ text=(
339
+ 'get the current weather in boston in celsius, the'
340
+ ' country should be US, the purpose is to know'
341
+ ' what to wear today?'
342
+ )
343
+ ),
344
+ types.Part.from_function_response(
345
+ name='get_current_weather',
346
+ response={
347
+ 'temperature': 21,
348
+ 'unit': 'C',
349
+ },
350
+ ),
351
+ types.Part(
352
+ text=(
353
+ 'get the current weather in new brunswick in celsius, the'
354
+ ' country should be US, the purpose is to know'
355
+ ' what to prepare an event today?'
356
+ )
357
+ ),
358
+ types.Part.from_function_response(
359
+ name='get_current_weather',
360
+ response={
361
+ 'temperature': 21,
362
+ 'unit': 'C',
363
+ },
364
+ ),
365
+ ]
366
+ chat = client.chats.create(
367
+ model='gemini-3-pro-preview',
368
+ history=previous_generate_content_history,
369
+ config=types.GenerateContentConfig(
370
+ tools=[{
371
+ 'function_declarations': gemini_function_declarations
372
+ }],
373
+ tool_config=types.ToolConfig(
374
+ function_calling_config={
375
+ 'stream_function_call_arguments': True,
376
+ }
377
+ ),
378
+ ),
379
+ )
380
+ for message in test_parts:
381
+ result = chat.send_message_stream(message)
382
+ for chunk in result:
383
+ assert chunk is not None
384
+ assert chunk.candidates is not None
385
+ assert chunk.candidates[0].content is not None
386
+ assert chunk.candidates[0].content.parts is not None
387
+
388
+ assert chat.get_history() is not None
389
+
390
+
391
+ @pytest.mark.asyncio
392
+ async def test_chat_streaming_with_json_parameters_with_history_async(client):
393
+ """Tests streaming function calls with FunctionDeclaration withJSON parameters."""
394
+ test_parts = [
395
+ types.Part(
396
+ text=(
397
+ 'get the current weather in boston in celsius, the'
398
+ ' country should be US, the purpose is to know'
399
+ ' what to wear today?'
400
+ )
401
+ ),
402
+ types.Part.from_function_response(
403
+ name='get_current_weather',
404
+ response={
405
+ 'temperature': 21,
406
+ 'unit': 'C',
407
+ },
408
+ ),
409
+ types.Part(
410
+ text=(
411
+ 'get the current weather in new brunswick in celsius, the'
412
+ ' country should be US, the purpose is to know'
413
+ ' what to prepare an event today?'
414
+ )
415
+ ),
416
+ types.Part.from_function_response(
417
+ name='get_current_weather',
418
+ response={
419
+ 'temperature': 21,
420
+ 'unit': 'C',
421
+ },
422
+ ),
423
+ ]
424
+ with pytest_helper.exception_if_mldev(client, ValueError):
425
+ chat = client.aio.chats.create(
426
+ model='gemini-3-pro-preview',
427
+ history=previous_generate_content_history,
428
+ config=types.GenerateContentConfig(
429
+ tools=[{'function_declarations': gemini_function_declarations}],
430
+ tool_config=types.ToolConfig(
431
+ function_calling_config={
432
+ 'stream_function_call_arguments': True,
433
+ }
434
+ ),
435
+ ),
436
+ )
437
+ for message in test_parts:
438
+ async for chunk in await chat.send_message_stream(message):
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