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,255 +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
- """Tests for batches.create() with inlined requests."""
18
- import base64
19
- import copy
20
- import datetime
21
- import os
22
-
23
- import pytest
24
-
25
- from ... import _transformers as t
26
- from ... import types
27
- from .. import pytest_helper
28
-
29
- _GEMINI_MODEL = 'gemini-2.5-flash'
30
- _DISPLAY_NAME = 'test_batch'
31
-
32
- _MLDEV_GEMINI_MODEL = 'gemini-2.5-flash'
33
-
34
- _SAFETY_SETTINGS = [
35
- {
36
- 'category': 'HARM_CATEGORY_HATE_SPEECH',
37
- 'threshold': 'BLOCK_ONLY_HIGH',
38
- },
39
- {
40
- 'category': 'HARM_CATEGORY_DANGEROUS_CONTENT',
41
- 'threshold': 'BLOCK_LOW_AND_ABOVE',
42
- },
43
- ]
44
-
45
- _INLINED_REQUEST = {
46
- 'contents': [{
47
- 'parts': [{
48
- 'text': 'Hello!',
49
- }],
50
- 'role': 'user',
51
- }],
52
- 'metadata': {
53
- 'key': 'request-1',
54
- },
55
- 'config': {
56
- 'safety_settings': _SAFETY_SETTINGS,
57
- },
58
- }
59
- _INLINED_TEXT_REQUEST_UNION = {
60
- 'contents': [{
61
- 'parts': [{
62
- 'text': 'high',
63
- }],
64
- 'role': 'user',
65
- }],
66
- 'config': {
67
- 'response_modalities': ['TEXT'],
68
- 'system_instruction': 'I say high, you say low',
69
- 'thinking_config': {
70
- 'include_thoughts': True,
71
- 'thinking_budget': 4000,
72
- },
73
- },
74
- }
75
- _INLINED_TEXT_REQUEST = copy.deepcopy(_INLINED_TEXT_REQUEST_UNION)
76
- _INLINED_TEXT_REQUEST['config']['system_instruction'] = t.t_content(
77
- 'I say high, you say low'
78
- )
79
- _INLINED_TEXT_REQUEST['config']['tools'] = [{'google_search': {}}]
80
- _INLINED_TEXT_REQUEST['config']['tool_config'] = {
81
- 'retrieval_config': {'lat_lng': {'latitude': 37.422, 'longitude': -122.084}}
82
- }
83
-
84
- _INLINED_IMAGE_REQUEST = {
85
- 'contents': [{
86
- 'parts': [
87
- {'text': 'What is in this image?'},
88
- {
89
- 'file_data': {
90
- 'file_uri': (
91
- 'https://generativelanguage.googleapis.com/v1beta/files/kje1wewvo85z'
92
- ),
93
- 'mime_type': 'image/jpeg',
94
- },
95
- },
96
- ],
97
- 'role': 'user',
98
- }],
99
- 'config': {
100
- 'temperature': 0.7,
101
- 'top_p': 0.9,
102
- 'top_k': 10,
103
- },
104
- }
105
- _INLINED_VIDEO_REQUEST = {
106
- 'contents': [{
107
- 'parts': [
108
- {
109
- 'text': 'Summerize this video.',
110
- },
111
- {
112
- 'file_data': {
113
- 'file_uri': (
114
- 'https://generativelanguage.googleapis.com/v1beta/files/tyvaih24jwje'
115
- ),
116
- 'mime_type': 'video/mp4',
117
- },
118
- 'video_metadata': {
119
- 'start_offset': '0s',
120
- 'end_offset': '5s',
121
- 'fps': 3,
122
- },
123
- },
124
- ],
125
- 'role': 'user',
126
- }],
127
- }
128
- _IMAGE_PNG_FILE_PATH = os.path.abspath(
129
- os.path.join(os.path.dirname(__file__), '../data/google.png')
130
- )
131
- with open(_IMAGE_PNG_FILE_PATH, 'rb') as image_file:
132
- image_bytes = image_file.read()
133
- image_string = base64.b64encode(image_bytes).decode('utf-8')
134
- _INLINED_IMAGE_BLOB_REQUEST = types.InlinedRequest(
135
- contents=[
136
- types.Content(
137
- parts=[
138
- types.Part(text='What is this image about?'),
139
- types.Part(
140
- inline_data=types.Blob(
141
- data=image_string,
142
- mime_type='image/png',
143
- ),
144
- ),
145
- ],
146
- role='user',
147
- )
148
- ]
149
- )
150
-
151
- # All tests will be run for both Vertex and MLDev.
152
- test_table: list[pytest_helper.TestTableItem] = [
153
- pytest_helper.TestTableItem(
154
- name='test_union_with_inlined_request',
155
- parameters=types._CreateBatchJobParameters(
156
- model=_MLDEV_GEMINI_MODEL,
157
- src=[_INLINED_REQUEST],
158
- config={
159
- 'display_name': _DISPLAY_NAME,
160
- },
161
- ),
162
- exception_if_vertex='not supported in Vertex',
163
- has_union=True,
164
- ),
165
- pytest_helper.TestTableItem(
166
- name='test_with_inlined_request',
167
- parameters=types._CreateBatchJobParameters(
168
- model=_MLDEV_GEMINI_MODEL,
169
- src={'inlined_requests': [_INLINED_REQUEST]},
170
- config={
171
- 'display_name': _DISPLAY_NAME,
172
- },
173
- ),
174
- exception_if_vertex='not supported',
175
- ),
176
- pytest_helper.TestTableItem(
177
- name='test_with_inlined_request_config',
178
- parameters=types._CreateBatchJobParameters(
179
- model=_MLDEV_GEMINI_MODEL,
180
- src={'inlined_requests': [_INLINED_TEXT_REQUEST]},
181
- config={
182
- 'display_name': _DISPLAY_NAME,
183
- },
184
- ),
185
- exception_if_vertex='not supported',
186
- ),
187
- pytest_helper.TestTableItem(
188
- name='test_union_with_inlined_request_system_instruction',
189
- parameters=types._CreateBatchJobParameters(
190
- model=_MLDEV_GEMINI_MODEL,
191
- src={'inlined_requests': [_INLINED_TEXT_REQUEST_UNION]},
192
- config={
193
- 'display_name': _DISPLAY_NAME,
194
- },
195
- ),
196
- has_union=True,
197
- exception_if_vertex='not supported',
198
- ),
199
- pytest_helper.TestTableItem(
200
- name='test_with_image_file',
201
- parameters=types._CreateBatchJobParameters(
202
- model=_MLDEV_GEMINI_MODEL,
203
- src={'inlined_requests': [_INLINED_IMAGE_REQUEST]},
204
- config={
205
- 'display_name': _DISPLAY_NAME,
206
- },
207
- ),
208
- exception_if_vertex='not supported',
209
- ),
210
- pytest_helper.TestTableItem(
211
- name='test_with_image_blob',
212
- parameters=types._CreateBatchJobParameters(
213
- model=_MLDEV_GEMINI_MODEL,
214
- src={'inlined_requests': [_INLINED_IMAGE_BLOB_REQUEST]},
215
- config={
216
- 'display_name': _DISPLAY_NAME,
217
- },
218
- ),
219
- exception_if_vertex='not supported',
220
- ),
221
- pytest_helper.TestTableItem(
222
- name='test_with_video_file',
223
- parameters=types._CreateBatchJobParameters(
224
- model=_MLDEV_GEMINI_MODEL,
225
- src={'inlined_requests': [_INLINED_VIDEO_REQUEST]},
226
- config={
227
- 'display_name': _DISPLAY_NAME,
228
- },
229
- ),
230
- exception_if_vertex='not supported',
231
- ),
232
- ]
233
-
234
- pytestmark = [
235
- pytest.mark.usefixtures('mock_timestamped_unique_name'),
236
- pytest_helper.setup(
237
- file=__file__,
238
- globals_for_file=globals(),
239
- test_method='batches.create',
240
- test_table=test_table,
241
- ),
242
- ]
243
-
244
-
245
- @pytest.mark.asyncio
246
- async def test_async_create(client):
247
- with pytest_helper.exception_if_vertex(client, ValueError):
248
- batch_job = await client.aio.batches.create(
249
- model=_GEMINI_MODEL,
250
- src=[_INLINED_REQUEST],
251
- )
252
- assert batch_job.name.startswith('batches/')
253
- assert (
254
- batch_job.model == 'models/' + _GEMINI_MODEL
255
- ) # Converted to Gemini full name.
@@ -1,86 +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
- """Tests for batches.delete()."""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
-
25
- _BATCH_JOB_NAME = '7085929781874655232'
26
- _BATCH_JOB_FULL_RESOURCE_NAME = (
27
- 'projects/964831358985/locations/us-central1/'
28
- f'batchPredictionJobs/{_BATCH_JOB_NAME}'
29
- )
30
- _INVALID_BATCH_JOB_NAME = 'invalid_name'
31
- _MLDEV_BATCH_OPERATION_NAME = 'batches/70h2jo0ic2t1zejyl0p4jgi8mk1gj0wvjusv'
32
-
33
-
34
- # All tests will be run for both Vertex and MLDev.
35
- test_table: list[pytest_helper.TestTableItem] = [
36
- pytest_helper.TestTableItem(
37
- name='test_delete_batch_job',
38
- parameters=types._DeleteBatchJobParameters(
39
- name=_BATCH_JOB_NAME,
40
- ),
41
- exception_if_mldev='Invalid batch job name',
42
- skip_in_api_mode=('Cannot cancel a batch job multiple times in Vertex'),
43
- ),
44
- pytest_helper.TestTableItem(
45
- name='test_delete_batch_job_full_resource_name',
46
- override_replay_id='test_delete_batch_job',
47
- parameters=types._DeleteBatchJobParameters(
48
- name=_BATCH_JOB_FULL_RESOURCE_NAME,
49
- ),
50
- exception_if_mldev='Invalid batch job name',
51
- skip_in_api_mode=('Cannot cancel a batch job multiple times in Vertex'),
52
- ),
53
- pytest_helper.TestTableItem(
54
- name='test_delete_batch_job_with_invalid_name',
55
- parameters=types._DeleteBatchJobParameters(
56
- name=_INVALID_BATCH_JOB_NAME,
57
- ),
58
- exception_if_mldev='Invalid batch job name',
59
- exception_if_vertex='Invalid batch job name',
60
- ),
61
- pytest_helper.TestTableItem(
62
- name='test_delete_batch_operation',
63
- parameters=types._DeleteBatchJobParameters(
64
- name=_MLDEV_BATCH_OPERATION_NAME,
65
- ),
66
- exception_if_vertex='Invalid batch job name',
67
- ),
68
- ]
69
-
70
- pytestmark = pytest_helper.setup(
71
- file=__file__,
72
- globals_for_file=globals(),
73
- test_method='batches.delete',
74
- test_table=test_table,
75
- )
76
-
77
-
78
- @pytest.mark.asyncio
79
- async def test_async_delete(client):
80
- if client.vertexai:
81
- name = _BATCH_JOB_NAME
82
- else:
83
- name = _MLDEV_BATCH_OPERATION_NAME
84
-
85
- delete_job = await client.aio.batches.delete(name=name)
86
- assert delete_job
@@ -1,157 +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
- """Tests for batches._create_embeddings()"""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
- _MLDEV_EMBEDDING_BATCH_INLINE_OPERATION_NAME = (
25
- 'batches/wdx71o8cgbzoa6gg3be1mg7g8ulrhapcjgo3'
26
- )
27
- _MLDEV_EMBEDDING_BATCH_FILE_OPERATION_NAME = (
28
- 'batches/507oatd242het8ox60pwsmn7tcmtkrj8itff'
29
- )
30
-
31
- _DISPLAY_NAME = 'test_batch'
32
- _MLDEV_EMBEDDING_MODEL = 'gemini-embedding-001'
33
- _EMBED_CONTENT_FILE_NAME = 'files/mq9e3mg3u2y5'
34
- _INLINED_EMBED_CONTENT_REQUESTS = {
35
- 'config': {'output_dimensionality': 64},
36
- 'contents': [
37
- {
38
- 'parts': [{
39
- 'text': '1',
40
- }],
41
- },
42
- {
43
- 'parts': [{
44
- 'text': '2',
45
- }],
46
- },
47
- {
48
- 'parts': [{
49
- 'text': '3',
50
- }],
51
- },
52
- ],
53
- }
54
-
55
- test_table: list[pytest_helper.TestTableItem] = [
56
- pytest_helper.TestTableItem(
57
- name='test_from_inlined',
58
- parameters=types._CreateEmbeddingsBatchJobParameters(
59
- model=_MLDEV_EMBEDDING_MODEL,
60
- src={'inlined_requests': _INLINED_EMBED_CONTENT_REQUESTS},
61
- config={
62
- 'display_name': _DISPLAY_NAME,
63
- },
64
- ),
65
- exception_if_vertex='Vertex AI does not support',
66
- ),
67
- ]
68
-
69
- pytestmark = [
70
- pytest.mark.usefixtures('mock_timestamped_unique_name'),
71
- pytest_helper.setup(
72
- file=__file__,
73
- globals_for_file=globals(),
74
- test_method='batches.create_embeddings',
75
- test_table=test_table,
76
- http_options={
77
- 'api_version': 'v1alpha',
78
- 'base_url': (
79
- 'https://autopush-generativelanguage.sandbox.googleapis.com'
80
- ),
81
- },
82
- ),
83
- ]
84
-
85
-
86
- @pytest.mark.asyncio
87
- async def test_async_from_inline(client):
88
- with pytest_helper.exception_if_vertex(client, ValueError):
89
- batch_job = await client.aio.batches.create_embeddings(
90
- model=_MLDEV_EMBEDDING_MODEL,
91
- src={'inlined_requests': _INLINED_EMBED_CONTENT_REQUESTS},
92
- )
93
- assert batch_job.name.startswith('batches/')
94
-
95
-
96
- def test_from_file(client):
97
- """Tests creating a batch job with an embedding file name."""
98
- with pytest_helper.exception_if_vertex(client, ValueError):
99
- batch_job = client.batches.create_embeddings(
100
- model=_MLDEV_EMBEDDING_MODEL,
101
- src={'file_name': _EMBED_CONTENT_FILE_NAME},
102
- config={
103
- 'display_name': _DISPLAY_NAME,
104
- },
105
- )
106
- assert batch_job.name.startswith('batches/')
107
- assert batch_job.model == 'models/' + _MLDEV_EMBEDDING_MODEL
108
-
109
-
110
- @pytest.mark.asyncio
111
- async def test_async_from_file(client):
112
- with pytest_helper.exception_if_vertex(client, ValueError):
113
- batch_job = await client.aio.batches.create_embeddings(
114
- model=_MLDEV_EMBEDDING_MODEL,
115
- src={'file_name': _EMBED_CONTENT_FILE_NAME},
116
- config={
117
- 'display_name': _DISPLAY_NAME,
118
- },
119
- )
120
- assert batch_job.name.startswith('batches/')
121
- assert (
122
- batch_job.model == 'models/' + _MLDEV_EMBEDDING_MODEL
123
- ) # Converted to Gemini full name.
124
-
125
-
126
- def test_get_inline(client):
127
- """Tests getting a batch job that used inline requests."""
128
- with pytest_helper.exception_if_vertex(client, ValueError):
129
- name = _MLDEV_EMBEDDING_BATCH_INLINE_OPERATION_NAME
130
- batch_job = client.batches.get(name=name)
131
- assert batch_job.dest.inlined_embed_content_responses is not None
132
-
133
-
134
- @pytest.mark.asyncio
135
- async def test_async_get_inline(client):
136
- with pytest_helper.exception_if_vertex(client, ValueError):
137
- name = _MLDEV_EMBEDDING_BATCH_INLINE_OPERATION_NAME
138
- batch_job = await client.aio.batches.get(name=name)
139
-
140
- assert batch_job.dest.inlined_embed_content_responses is not None
141
-
142
-
143
- def test_get_file(client):
144
- """Tests getting a batch job that used a file source."""
145
- with pytest_helper.exception_if_vertex(client, ValueError):
146
- name = _MLDEV_EMBEDDING_BATCH_FILE_OPERATION_NAME
147
- batch_job = client.batches.get(name=name)
148
- assert batch_job.dest.file_name is not None
149
-
150
-
151
- @pytest.mark.asyncio
152
- async def test_async_get_file(client):
153
- with pytest_helper.exception_if_vertex(client, ValueError):
154
- name = _MLDEV_EMBEDDING_BATCH_FILE_OPERATION_NAME
155
- batch_job = await client.aio.batches.get(name=name)
156
-
157
- assert batch_job.dest.file_name is not None
@@ -1,78 +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
- """Tests for batches.get()."""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
-
25
- # Vertex AI batch job name.
26
- _BATCH_JOB_NAME = '5798522612028014592'
27
- _BATCH_JOB_FULL_RESOURCE_NAME = (
28
- 'projects/964831358985/locations/us-central1/'
29
- f'batchPredictionJobs/{_BATCH_JOB_NAME}'
30
- )
31
- # MLDev batch operation name.
32
- _MLDEV_BATCH_OPERATION_NAME = 'batches/0yew7plxupyybd7appsrq5vw7w0lp3l79lab'
33
- _INVALID_BATCH_JOB_NAME = 'invalid_name'
34
-
35
-
36
- # All tests will be run for both Vertex and MLDev.
37
- test_table: list[pytest_helper.TestTableItem] = [
38
- pytest_helper.TestTableItem(
39
- name='test_get_batch_job',
40
- parameters=types._GetBatchJobParameters(
41
- name=_BATCH_JOB_NAME,
42
- ),
43
- exception_if_mldev='Invalid batch job name',
44
- ),
45
- pytest_helper.TestTableItem(
46
- name='test_get_batch_operation',
47
- parameters=types._GetBatchJobParameters(
48
- name=_MLDEV_BATCH_OPERATION_NAME,
49
- ),
50
- exception_if_vertex='Invalid batch job name',
51
- ),
52
- pytest_helper.TestTableItem(
53
- name='test_get_batch_job_with_invalid_name',
54
- parameters=types._GetBatchJobParameters(
55
- name=_INVALID_BATCH_JOB_NAME,
56
- ),
57
- exception_if_mldev='Invalid batch job name',
58
- exception_if_vertex='Invalid batch job name',
59
- ),
60
- ]
61
-
62
- pytestmark = pytest_helper.setup(
63
- file=__file__,
64
- globals_for_file=globals(),
65
- test_method='batches.get',
66
- test_table=test_table,
67
- )
68
-
69
-
70
- @pytest.mark.asyncio
71
- async def test_async_get(client):
72
- if client.vertexai:
73
- name = _BATCH_JOB_NAME
74
- else:
75
- name = _MLDEV_BATCH_OPERATION_NAME
76
- batch_job = await client.aio.batches.get(name=name)
77
-
78
- assert batch_job
@@ -1,79 +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
- """Tests for batches.list()."""
18
-
19
- import pytest
20
-
21
- from ... import errors
22
- from ... import types
23
- from .. import pytest_helper
24
-
25
-
26
- # All tests will be run for both Vertex and MLDev.
27
- test_table: list[pytest_helper.TestTableItem] = [
28
- pytest_helper.TestTableItem(
29
- name='test_list_batch_jobs',
30
- parameters=types._ListBatchJobsParameters(
31
- config=types.ListBatchJobsConfig(
32
- page_size=5,
33
- ),
34
- ),
35
- ),
36
- pytest_helper.TestTableItem(
37
- name='test_list_batch_jobs_with_config',
38
- parameters=types._ListBatchJobsParameters(
39
- config=types.ListBatchJobsConfig(
40
- filter='display_name:"genai_*"',
41
- page_size=5,
42
- ),
43
- ),
44
- exception_if_mldev='filter parameter is not supported in Gemini API',
45
- ),
46
- ]
47
-
48
- pytestmark = pytest_helper.setup(
49
- file=__file__,
50
- globals_for_file=globals(),
51
- test_method='batches.list',
52
- test_table=test_table,
53
- )
54
-
55
-
56
- def test_pager(client):
57
- batch_jobs = client.batches.list(config={'page_size': 10})
58
- assert 'content-type' in batch_jobs.sdk_http_response.headers
59
- assert batch_jobs.name == 'batch_jobs'
60
- assert batch_jobs.page_size == 10
61
- assert len(batch_jobs) <= 10
62
-
63
- # Iterate through the first page. Otherwise, too many batches are returned.
64
- for _ in batch_jobs.page:
65
- pass
66
-
67
-
68
- @pytest.mark.asyncio
69
- async def test_async_pager(client):
70
- batch_jobs = await client.aio.batches.list(config={'page_size': 10})
71
-
72
- assert 'Content-Type' in batch_jobs.sdk_http_response.headers
73
- assert batch_jobs.name == 'batch_jobs'
74
- assert batch_jobs.page_size == 10
75
- assert len(batch_jobs) <= 10
76
-
77
- # Iterate through the first page. Otherwise, too many batches are returned.
78
- for _ in batch_jobs.page:
79
- pass
@@ -1,17 +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
- """Tests for the Google GenAI SDK's caches module."""
@@ -1,29 +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
- """Constants for caches tests."""
18
-
19
- CACHED_CONTENT_NAME_MLDEV = 'cachedContents/o239k1gxzz0juy9wqstndhncr85krehehf551hqh'
20
- CACHED_CONTENT_NAME_VERTEX = 'cachedContents/2164089915711684608'
21
-
22
- VERTEX_HTTP_OPTIONS = {
23
- 'api_version': 'v1beta1',
24
- 'base_url': 'https://us-central1-aiplatform.googleapis.com/',
25
- }
26
- MLDEV_HTTP_OPTIONS = {
27
- 'api_version': 'v1beta',
28
- 'base_url': 'https://generativelanguage.googleapis.com/',
29
- }