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,417 +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
- """Unit Tests for the APIError class.
18
-
19
- End to end tests should be in models/test_generate_content.py.
20
- """
21
-
22
- import pickle
23
-
24
- import httpx
25
- import pytest
26
-
27
- from ... import errors
28
-
29
-
30
- def test_constructor_code_none_error_in_json_code_in_error():
31
-
32
- actual_error = errors.APIError(
33
- None,
34
- {
35
- 'error': {
36
- 'code': 400,
37
- 'message': 'error message',
38
- 'status': 'INVALID_ARGUMENT',
39
- }
40
- },
41
- httpx.Response(status_code=400),
42
- )
43
-
44
- assert actual_error.code == 400
45
- assert actual_error.message == 'error message'
46
- assert actual_error.status == 'INVALID_ARGUMENT'
47
- assert actual_error.details == {
48
- 'error': {
49
- 'code': 400,
50
- 'message': 'error message',
51
- 'status': 'INVALID_ARGUMENT',
52
- }
53
- }
54
-
55
-
56
- def test_constructor_code_none_error_in_json_code_outside_error():
57
-
58
- actual_error = errors.APIError(
59
- None,
60
- {
61
- 'code': 400,
62
- 'error': {
63
- 'code': 500,
64
- 'message': 'error message',
65
- 'status': 'INVALID_ARGUMENT',
66
- },
67
- },
68
- httpx.Response(status_code=400),
69
- )
70
-
71
- assert actual_error.code == 400
72
- assert actual_error.message == 'error message'
73
- assert actual_error.status == 'INVALID_ARGUMENT'
74
- assert actual_error.details == {
75
- 'code': 400,
76
- 'error': {
77
- 'code': 500,
78
- 'message': 'error message',
79
- 'status': 'INVALID_ARGUMENT',
80
- },
81
- }
82
-
83
-
84
- def test_constructor_code_not_present():
85
-
86
- actual_error = errors.APIError(
87
- None,
88
- {
89
- 'error': {
90
- 'message': 'error message',
91
- 'status': 'INVALID_ARGUMENT',
92
- }
93
- },
94
- httpx.Response(status_code=400),
95
- )
96
-
97
- assert actual_error.code is None
98
- assert actual_error.message == 'error message'
99
- assert actual_error.status == 'INVALID_ARGUMENT'
100
- assert actual_error.details == {
101
- 'error': {
102
- 'message': 'error message',
103
- 'status': 'INVALID_ARGUMENT',
104
- }
105
- }
106
-
107
-
108
- def test_constructor_code_exist_error_in_json():
109
-
110
- actual_error = errors.APIError(
111
- 400,
112
- {
113
- 'error': {
114
- 'code': 400,
115
- 'message': 'error message',
116
- 'status': 'INVALID_ARGUMENT',
117
- }
118
- },
119
- httpx.Response(status_code=400),
120
- )
121
-
122
- assert actual_error.code == 400
123
- assert actual_error.message == 'error message'
124
- assert actual_error.status == 'INVALID_ARGUMENT'
125
- assert actual_error.details == {
126
- 'error': {
127
- 'code': 400,
128
- 'message': 'error message',
129
- 'status': 'INVALID_ARGUMENT',
130
- }
131
- }
132
-
133
-
134
- def test_constructor_error_not_in_json():
135
-
136
- actual_error = errors.APIError(
137
- 400,
138
- {
139
- 'message': 'error message',
140
- 'status': 'INVALID_ARGUMENT',
141
- 'code': 400,
142
- },
143
- httpx.Response(status_code=400),
144
- )
145
-
146
- assert actual_error.code == 400
147
- assert actual_error.message == 'error message'
148
- assert actual_error.status == 'INVALID_ARGUMENT'
149
- assert actual_error.details == {
150
- 'message': 'error message',
151
- 'status': 'INVALID_ARGUMENT',
152
- 'code': 400,
153
- }
154
-
155
-
156
- def test_constructor_error_in_json_status_outside_error():
157
-
158
- actual_error = errors.APIError(
159
- 400,
160
- {
161
- 'status': 'OUTER_INVALID_ARGUMENT_STATUS',
162
- 'error': {
163
- 'code': 400,
164
- 'message': 'error message',
165
- 'status': 'INNER_INVALID_ARGUMENT_STATUS',
166
- },
167
- },
168
- httpx.Response(status_code=400),
169
- )
170
-
171
- assert actual_error.code == 400
172
- assert actual_error.message == 'error message'
173
- assert actual_error.status == 'OUTER_INVALID_ARGUMENT_STATUS'
174
- assert actual_error.details == {
175
- 'status': 'OUTER_INVALID_ARGUMENT_STATUS',
176
- 'error': {
177
- 'code': 400,
178
- 'message': 'error message',
179
- 'status': 'INNER_INVALID_ARGUMENT_STATUS',
180
- },
181
- }
182
-
183
-
184
- def test_constructor_status_not_present():
185
-
186
- actual_error = errors.APIError(
187
- 400,
188
- {
189
- 'error': {
190
- 'code': 400,
191
- 'message': 'error message',
192
- }
193
- },
194
- httpx.Response(status_code=400),
195
- )
196
-
197
- assert actual_error.code == 400
198
- assert actual_error.message == 'error message'
199
- assert actual_error.status == None
200
- assert actual_error.details == {
201
- 'error': {
202
- 'code': 400,
203
- 'message': 'error message',
204
- }
205
- }
206
-
207
-
208
- def test_constructor_error_in_json_message_outside_error():
209
-
210
- actual_error = errors.APIError(
211
- 400,
212
- {
213
- 'message': 'OUTER_ERROR_MESSAGE',
214
- 'error': {
215
- 'code': 400,
216
- 'message': 'INNER_ERROR_MESSAGE',
217
- 'status': 'INVALID_ARGUMENT',
218
- },
219
- },
220
- httpx.Response(status_code=400),
221
- )
222
-
223
- assert actual_error.code == 400
224
- assert actual_error.message == 'OUTER_ERROR_MESSAGE'
225
- assert actual_error.status == 'INVALID_ARGUMENT'
226
- assert actual_error.details == {
227
- 'message': 'OUTER_ERROR_MESSAGE',
228
- 'error': {
229
- 'code': 400,
230
- 'message': 'INNER_ERROR_MESSAGE',
231
- 'status': 'INVALID_ARGUMENT',
232
- },
233
- }
234
-
235
-
236
- def test_constructor_message_not_present():
237
-
238
- actual_error = errors.APIError(
239
- 400,
240
- {
241
- 'error': {
242
- 'code': 400,
243
- 'status': 'INVALID_ARGUMENT',
244
- }
245
- },
246
- httpx.Response(status_code=400),
247
- )
248
-
249
- assert actual_error.code == 400
250
- assert actual_error.message is None
251
- assert actual_error.status == 'INVALID_ARGUMENT'
252
- assert actual_error.details == {
253
- 'error': {
254
- 'code': 400,
255
- 'status': 'INVALID_ARGUMENT',
256
- }
257
- }
258
-
259
-
260
- def test_raise_for_response_code_exist_json_decoder_error():
261
- class FakeResponse(httpx.Response):
262
-
263
- def read(self) -> bytes:
264
- self._content = b'{"data": {"key1": "value1", "key2"}'
265
- return self._content
266
-
267
- try:
268
- errors.APIError.raise_for_response(
269
- FakeResponse(
270
- status_code=503,
271
- extensions={'reason_phrase': b'Service Unavailable'},
272
- )
273
- )
274
- except errors.ServerError as actual_error:
275
- assert actual_error.code == 503
276
- assert actual_error.message == '{"data": {"key1": "value1", "key2"}'
277
- assert actual_error.status == 'Service Unavailable'
278
- assert actual_error.details == {
279
- 'message': '{"data": {"key1": "value1", "key2"}',
280
- 'status': 'Service Unavailable',
281
- }
282
-
283
-
284
- def test_raise_for_response_client_error():
285
- class FakeResponse(httpx.Response):
286
-
287
- def read(self) -> bytes:
288
- self._content = (
289
- b'{"error": {"code": 400, "message": "error message", "status":'
290
- b' "INVALID_ARGUMENT"}}'
291
- )
292
- return self._content
293
-
294
- try:
295
- errors.APIError.raise_for_response(FakeResponse(status_code=400))
296
- except errors.ClientError as actual_error:
297
- assert actual_error.code == 400
298
- assert actual_error.message == 'error message'
299
- assert actual_error.status == 'INVALID_ARGUMENT'
300
- assert actual_error.details == {
301
- 'error': {
302
- 'code': 400,
303
- 'message': 'error message',
304
- 'status': 'INVALID_ARGUMENT',
305
- }
306
- }
307
-
308
-
309
- def test_raise_for_response_server_error():
310
- class FakeResponse(httpx.Response):
311
-
312
- def read(self) -> bytes:
313
- self._content = (
314
- b'{"error": {"code": 500, "message": "error message", "status":'
315
- b' "SERVER_INTERNAL ERROR"}}'
316
- )
317
- return self._content
318
-
319
- try:
320
- errors.APIError.raise_for_response(FakeResponse(status_code=500))
321
- except errors.ServerError as actual_error:
322
- assert actual_error.code == 500
323
- assert actual_error.message == 'error message'
324
- assert actual_error.status == 'SERVER_INTERNAL ERROR'
325
- assert actual_error.details == {
326
- 'error': {
327
- 'code': 500,
328
- 'message': 'error message',
329
- 'status': 'SERVER_INTERNAL ERROR',
330
- }
331
- }
332
-
333
-
334
- def test_api_error_is_picklable():
335
- pickled_error = pickle.loads(pickle.dumps(errors.APIError(1, {})))
336
- assert isinstance(pickled_error, errors.APIError)
337
-
338
-
339
- @pytest.mark.asyncio
340
- async def test_raise_for_async_response_client_error():
341
- class FakeResponse(httpx.Response):
342
-
343
- async def aread(self) -> bytes:
344
- self._content = (
345
- b'{"error": {"code": 400, "message": "error message", "status":'
346
- b' "INVALID_ARGUMENT"}}'
347
- )
348
- return self._content
349
-
350
- try:
351
- await errors.APIError.raise_for_async_response(
352
- FakeResponse(status_code=400)
353
- )
354
- except errors.ClientError as actual_error:
355
- assert actual_error.code == 400
356
- assert actual_error.message == 'error message'
357
- assert actual_error.status == 'INVALID_ARGUMENT'
358
- assert actual_error.details == {
359
- 'error': {
360
- 'code': 400,
361
- 'message': 'error message',
362
- 'status': 'INVALID_ARGUMENT',
363
- }
364
- }
365
-
366
-
367
- @pytest.mark.asyncio
368
- async def test_raise_for_async_response_server_error():
369
- class FakeResponse(httpx.Response):
370
-
371
- async def aread(self) -> bytes:
372
- self._content = (
373
- b'{"error": {"code": 500, "message": "error message", "status":'
374
- b' "SERVER_INTERNAL ERROR"}}'
375
- )
376
- return self._content
377
-
378
- try:
379
- await errors.APIError.raise_for_async_response(
380
- FakeResponse(status_code=500)
381
- )
382
- except errors.ServerError as actual_error:
383
- assert actual_error.code == 500
384
- assert actual_error.message == 'error message'
385
- assert actual_error.status == 'SERVER_INTERNAL ERROR'
386
- assert actual_error.details == {
387
- 'error': {
388
- 'code': 500,
389
- 'message': 'error message',
390
- 'status': 'SERVER_INTERNAL ERROR',
391
- }
392
- }
393
-
394
-
395
- @pytest.mark.asyncio
396
- async def test_raise_for_async_response_code_exist_json_decoder_error():
397
- class FakeResponse(httpx.Response):
398
-
399
- async def aread(self) -> bytes:
400
- self._content = b'{"data": {"key1": "value1", "key2"}'
401
- return self._content
402
-
403
- try:
404
- await errors.APIError.raise_for_async_response(
405
- FakeResponse(
406
- status_code=503,
407
- extensions={'reason_phrase': b'Service Unavailable'},
408
- )
409
- )
410
- except errors.ServerError as actual_error:
411
- assert actual_error.code == 503
412
- assert actual_error.message == '{"data": {"key1": "value1", "key2"}'
413
- assert actual_error.status == 'Service Unavailable'
414
- assert actual_error.details == {
415
- 'message': '{"data": {"key1": "value1", "key2"}',
416
- 'status': 'Service Unavailable',
417
- }
@@ -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 file search stores module."""
@@ -1,66 +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 file_search_stores.create()."""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
- # All tests will be run for both Vertex and MLDev.
25
- test_table: list[pytest_helper.TestTableItem] = [
26
- pytest_helper.TestTableItem(
27
- name="test_display_name",
28
- parameters=types._CreateFileSearchStoreParameters(
29
- config=types.CreateFileSearchStoreConfig(
30
- display_name="My File Search Store"
31
- )
32
- ),
33
- exception_if_vertex="only supported in the Gemini Developer client",
34
- ),
35
- pytest_helper.TestTableItem(
36
- name="test_basic",
37
- parameters=types._CreateFileSearchStoreParameters(),
38
- exception_if_vertex="only supported in the Gemini Developer client",
39
- ),
40
- ]
41
-
42
- pytestmark = [
43
- pytest.mark.usefixtures("mock_timestamped_unique_name"),
44
- pytest_helper.setup(
45
- file=__file__,
46
- globals_for_file=globals(),
47
- test_method="file_search_stores.create",
48
- test_table=test_table,
49
- ),
50
- ]
51
-
52
-
53
- @pytest.mark.asyncio
54
- async def test_async_display_name(client):
55
- with pytest_helper.exception_if_vertex(client, ValueError):
56
- file_search_store = await client.aio.file_search_stores.create(
57
- config=types.CreateFileSearchStoreConfig(
58
- display_name="My File Search Store"
59
- )
60
- )
61
-
62
-
63
- @pytest.mark.asyncio
64
- async def test_async_basic(client):
65
- with pytest_helper.exception_if_vertex(client, ValueError):
66
- file_search_store = await client.aio.file_search_stores.create()
@@ -1,64 +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 file_search_stores.delete()."""
17
-
18
- import pytest
19
-
20
- from ... import types
21
- from .. import pytest_helper
22
-
23
- # All tests will be run for both Vertex and MLDev.
24
- test_table: list[pytest_helper.TestTableItem] = [
25
- pytest_helper.TestTableItem(
26
- name="test_delete_with_name",
27
- parameters=types._DeleteFileSearchStoreParameters(
28
- name="fileSearchStores/acxjj7m366ln-aw6xyp94icll",
29
- ),
30
- exception_if_vertex="only supported in the Gemini Developer client",
31
- ),
32
- pytest_helper.TestTableItem(
33
- name="test_delete_with_name_and_force",
34
- parameters=types._DeleteFileSearchStoreParameters(
35
- name="fileSearchStores/7igesc9r2zw9-0mpxpsqubv7s",
36
- config=types.DeleteFileSearchStoreConfig(force=True),
37
- ),
38
- exception_if_vertex="only supported in the Gemini Developer client",
39
- ),
40
- ]
41
-
42
- pytestmark = pytest_helper.setup(
43
- file=__file__,
44
- globals_for_file=globals(),
45
- test_method="file_search_stores.delete",
46
- test_table=test_table,
47
- )
48
-
49
-
50
- @pytest.mark.asyncio
51
- async def test_async_delete(client):
52
- with pytest_helper.exception_if_vertex(client, ValueError):
53
- await client.aio.file_search_stores.delete(
54
- name="fileSearchStores/my-file-search-store-l65kcyel9lkz"
55
- )
56
-
57
-
58
- @pytest.mark.asyncio
59
- async def test_async_force_delete(client):
60
- with pytest_helper.exception_if_vertex(client, ValueError):
61
- await client.aio.file_search_stores.delete(
62
- name="fileSearchStores/my-file-search-store-vjtrjw6re8oz",
63
- config=types.DeleteFileSearchStoreConfig(force=True),
64
- )
@@ -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
-
16
-
17
- """Tests for file_search_stores.get()."""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
- # A FileSearchStore name known to exist in the test environment.
25
- # Replace with a real one from your test setup.
26
- _EXISTING_FILE_SEARCH_STORE_NAME = "fileSearchStores/5en07ei3kojo-yo8sjqgvx2xf"
27
- _NON_EXISTENT_FILE_SEARCH_STORE_NAME = (
28
- "fileSearchStores/non-existent-file-search-store"
29
- )
30
- _INVALID_FILE_SEARCH_STORE_NAME = (
31
- "fileSearchStores/_invalid_file_search_store_name"
32
- )
33
- _NOT_A_FILE_SEARCH_STORE_NAME = "genai-test-file-search-store"
34
-
35
- # All tests will be run for both Vertex and MLDev.
36
- test_table: list[pytest_helper.TestTableItem] = [
37
- pytest_helper.TestTableItem(
38
- name="test_get_success",
39
- parameters=types._GetFileSearchStoreParameters(
40
- name=_EXISTING_FILE_SEARCH_STORE_NAME
41
- ),
42
- exception_if_vertex="only supported in the Gemini Developer client",
43
- ),
44
- pytest_helper.TestTableItem(
45
- name="test_get_not_found",
46
- parameters=types._GetFileSearchStoreParameters(
47
- name=_NON_EXISTENT_FILE_SEARCH_STORE_NAME
48
- ),
49
- exception_if_vertex="only supported in the Gemini Developer client",
50
- # Expect an exception to be raised by the mock
51
- exception_if_mldev="PERMISSION_DENIED",
52
- ),
53
- pytest_helper.TestTableItem(
54
- name="test_get_invalid_name",
55
- parameters=types._GetFileSearchStoreParameters(
56
- name=_INVALID_FILE_SEARCH_STORE_NAME
57
- ),
58
- exception_if_vertex="only supported in the Gemini Developer client",
59
- # Validation should catch this before the API call
60
- exception_if_mldev="INVALID_ARGUMENT",
61
- ),
62
- pytest_helper.TestTableItem(
63
- name="test_get_not_a_file_search_store_name",
64
- parameters=types._GetFileSearchStoreParameters(
65
- name=_NOT_A_FILE_SEARCH_STORE_NAME
66
- ),
67
- exception_if_vertex="only supported in the Gemini Developer client",
68
- exception_if_mldev="Not Found",
69
- ),
70
- ]
71
-
72
- pytestmark = pytest_helper.setup(
73
- file=__file__,
74
- globals_for_file=globals(),
75
- test_method="file_search_stores.get",
76
- test_table=test_table,
77
- )
78
-
79
-
80
- @pytest.mark.asyncio
81
- async def test_async_get(client):
82
- with pytest_helper.exception_if_vertex(client, ValueError):
83
- # This test relies on the mocking/replays set up by pytest_helper
84
- # For a success case:
85
- try:
86
- file_search_store = await client.aio.file_search_stores.get(
87
- name=_EXISTING_FILE_SEARCH_STORE_NAME
88
- )
89
- assert file_search_store is not None
90
- assert file_search_store.name == _EXISTING_FILE_SEARCH_STORE_NAME
91
- except Exception as e:
92
- # Depending on the mock setup, errors might be raised directly
93
- print(f"Async get failed: {e}")
94
- raise