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,104 +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 models.get."""
18
-
19
- import pytest
20
- from ... import errors
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
-
25
- test_http_options = {'api_version': 'v1', 'headers': {'test': 'headers'}}
26
-
27
- test_table: list[pytest_helper.TestTableItem] = [
28
- pytest_helper.TestTableItem(
29
- name='test_get_vertex_tuned_model',
30
- parameters=types._GetModelParameters(
31
- model='models/2171259487439028224'
32
- ),
33
- exception_if_mldev='404',
34
- ),
35
- pytest_helper.TestTableItem(
36
- name='test_get_mldev_tuned_model',
37
- parameters=types._GetModelParameters(
38
- model='tunedModels/generatenum5443-ekrw7ie9wis23zbeogbw6jq8'
39
- ),
40
- exception_if_vertex='404',
41
- ),
42
- pytest_helper.TestTableItem(
43
- name='test_get_vertex_tuned_model_with_http_options_in_method',
44
- parameters=types._GetModelParameters(
45
- model='models/2171259487439028224',
46
- config={
47
- 'http_options': test_http_options,
48
- },
49
- ),
50
- exception_if_mldev='404',
51
- ),
52
- pytest_helper.TestTableItem(
53
- name='test_get_mldev_base_model_with_http_options_in_method',
54
- parameters=types._GetModelParameters(
55
- model='gemini-2.5-flash',
56
- config={
57
- 'http_options': test_http_options,
58
- },
59
- ),
60
- ),
61
- pytest_helper.TestTableItem(
62
- name='test_get_base_model',
63
- parameters=types._GetModelParameters(model='gemini-2.5-flash'),
64
- ),
65
- pytest_helper.TestTableItem(
66
- name='test_get_base_model_with_models_prefix',
67
- parameters=types._GetModelParameters(model='models/gemini-2.5-flash'),
68
- exception_if_vertex='400',
69
- ),
70
- ]
71
- pytestmark = pytest_helper.setup(
72
- file=__file__,
73
- globals_for_file=globals(),
74
- test_method='models.get',
75
- test_table=test_table,
76
- )
77
-
78
-
79
- @pytest.mark.asyncio
80
- async def test_async_get_tuned_model(client):
81
- if client._api_client.vertexai:
82
- with pytest.raises(errors.ClientError) as e:
83
- await client.aio.models.get(model='tunedModels/generate-num-1896')
84
- assert '404' in str(e)
85
- else:
86
- response = await client.aio.models.get(
87
- model='tunedModels/generate-num-1896'
88
- )
89
-
90
-
91
- @pytest.mark.asyncio
92
- async def test_async_get_model(client):
93
- if client._api_client.vertexai:
94
- response = await client.aio.models.get(
95
- model='models/7687416965014487040',
96
- config={'http_options': test_http_options},
97
- )
98
- else:
99
- with pytest.raises(errors.ClientError) as e:
100
- await client.aio.models.get(
101
- model='models/7687416965014487040',
102
- config={'http_options': test_http_options},
103
- )
104
- assert '404' in str(e)
@@ -1,233 +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 models.list."""
18
-
19
- from unittest import mock
20
-
21
- import pytest
22
-
23
- from ... import client as genai_client
24
- from ... import _api_client
25
- from ... import types
26
- from .. import pytest_helper
27
-
28
- test_http_options = {'headers': {'test': 'headers'}}
29
-
30
- test_table: list[pytest_helper.TestTableItem] = [
31
- pytest_helper.TestTableItem(
32
- name='test_tuned_models',
33
- parameters=types._ListModelsParameters(
34
- config={'query_base': False, 'page_size': 3}
35
- ),
36
- ),
37
- pytest_helper.TestTableItem(
38
- name='test_tuned_models_with_filter',
39
- parameters=types._ListModelsParameters(
40
- config={'query_base': False,
41
- 'page_size': 3,
42
- 'filter': 'displayName="gemini-2.5-flash-1b0689e3-9773-43b4-97eb-c8140d5f183b"'}
43
- ),
44
- ),
45
- pytest_helper.TestTableItem(
46
- name='test_base_models',
47
- parameters=types._ListModelsParameters(),
48
- ),
49
- pytest_helper.TestTableItem(
50
- name='test_base_models_with_config',
51
- parameters=types._ListModelsParameters(config={'query_base': True, 'page_size': 10}),
52
- ),
53
- pytest_helper.TestTableItem(
54
- name='test_with_config',
55
- parameters=types._ListModelsParameters(config={'page_size': 3}),
56
- ),
57
- pytest_helper.TestTableItem(
58
- name='test_list_models_with_http_options_in_method',
59
- parameters=types._ListModelsParameters(
60
- config={'page_size': 3, 'http_options': test_http_options}
61
- ),
62
- ),
63
- ]
64
- pytestmark = pytest_helper.setup(
65
- file=__file__,
66
- globals_for_file=globals(),
67
- test_method='models.list',
68
- test_table=test_table,
69
- )
70
-
71
-
72
- @pytest.fixture()
73
- def mock_api_client():
74
- api_client = mock.MagicMock(spec=genai_client.BaseApiClient)
75
- api_client.api_key = 'fake_api_key'
76
- api_client._host = lambda: 'fake_host'
77
- api_client._http_options = {'headers': {}}
78
- api_client.vertexai = False
79
- return api_client
80
-
81
-
82
- def test_tuned_models_pager(client):
83
- pager = client.models.list(config={'page_size': 10})
84
-
85
- assert pager.name == 'models'
86
- assert pager.page_size == 10
87
- assert len(pager) <= 10
88
-
89
- # Iterate through all the pages. Then next_page() should raise an exception.
90
- for _ in pager:
91
- pass
92
- with pytest.raises(IndexError, match='No more pages to fetch.'):
93
- pager.next_page()
94
-
95
-
96
- def test_base_models_pager(client):
97
- pager = client.models.list(config={'page_size': 10, 'query_base': True})
98
-
99
- assert pager.name == 'models'
100
- assert pager.page_size == 10
101
- assert len(pager) <= 10
102
-
103
- # Iterate through all the pages. Then next_page() should raise an exception.
104
- for _ in pager:
105
- assert 'content-type' in pager.sdk_http_response.headers
106
- assert 'content-encoding' in pager.sdk_http_response.headers
107
- pass
108
- with pytest.raises(IndexError, match='No more pages to fetch.'):
109
- pager.next_page()
110
-
111
-
112
- def test_base_response_with_empty_json_payload_and_http_headers(
113
- mock_api_client, client
114
- ):
115
- with mock.patch.object(
116
- genai_client.Client, '_get_api_client'
117
- ) as patch_api_client:
118
- patch_api_client.return_value = mock_api_client
119
- mock_client = genai_client.Client()
120
- sdk_http_response = types.HttpResponse(
121
- headers={'header_key': 'header_value'},
122
- body='{}',
123
- )
124
- with mock.patch.object(
125
- mock_api_client, 'request', return_value=sdk_http_response
126
- ):
127
- pager = mock_client.models.list()
128
-
129
- assert len(pager) == 0
130
-
131
-
132
- def test_unknown_json_payload(mock_api_client, client):
133
- with mock.patch.object(
134
- genai_client.Client, '_get_api_client'
135
- ) as patch_api_client:
136
- patch_api_client.return_value = mock_api_client
137
- mock_client = genai_client.Client()
138
- sdk_http_response = types.HttpResponse(
139
- headers={'header_key': 'header_value'},
140
- body='{"unknown_key": "unknown_value"}',
141
- )
142
- with mock.patch.object(
143
- mock_api_client, 'request', return_value=sdk_http_response
144
- ) :
145
- pager = mock_client.models.list()
146
-
147
- assert len(pager) == 0
148
-
149
-
150
- def test_empty_json_payload(mock_api_client, client):
151
- with mock.patch.object(
152
- genai_client.Client, '_get_api_client'
153
- ) as patch_api_client:
154
- patch_api_client.return_value = mock_api_client
155
- mock_client = genai_client.Client()
156
- sdk_http_response = types.HttpResponse(
157
- headers={'header_key': 'header_value'},
158
- body='',
159
- )
160
- with mock.patch.object(
161
- mock_api_client, 'request', return_value=sdk_http_response
162
- ) :
163
- pager = mock_client.models.list()
164
-
165
- assert len(pager) == 0
166
-
167
-
168
- def test_empty_api_response_none_headers(mock_api_client, client):
169
- with mock.patch.object(
170
- genai_client.Client, '_get_api_client'
171
- ) as patch_api_client:
172
- patch_api_client.return_value = mock_api_client
173
- mock_client = genai_client.Client()
174
- sdk_http_response = types.HttpResponse(
175
- headers=None,
176
- body='{}',
177
- )
178
- with mock.patch.object(
179
- mock_api_client, 'request', return_value=sdk_http_response
180
- ):
181
- pager = mock_client.models.list()
182
-
183
- assert len(pager) == 0
184
-
185
-
186
- def test_empty_api_response_empty_dict_headers(mock_api_client, client):
187
- with mock.patch.object(
188
- genai_client.Client, '_get_api_client'
189
- ) as patch_api_client:
190
- patch_api_client.return_value = mock_api_client
191
- mock_client = genai_client.Client()
192
- sdk_http_response = types.HttpResponse(
193
- headers={},
194
- body='{}',
195
- )
196
- with mock.patch.object(
197
- mock_api_client, 'request', return_value=sdk_http_response
198
- ):
199
- pager = mock_client.models.list()
200
-
201
- assert len(pager) == 0
202
-
203
-
204
- @pytest.mark.asyncio
205
- async def test_tuned_models_async_pager(client):
206
- pager = await client.aio.models.list(config={'page_size': 3, 'query_base': False})
207
-
208
- assert 'Content-Type' in pager.sdk_http_response.headers
209
- assert 'Content-Encoding' in pager.sdk_http_response.headers
210
- assert pager.name == 'models'
211
- assert pager.page_size == 3
212
- assert len(pager) <= 3
213
-
214
- # Iterate through all the pages. Then next_page() should raise an exception.
215
- async for _ in pager:
216
- pass
217
- with pytest.raises(IndexError, match='No more pages to fetch.'):
218
- await pager.next_page()
219
-
220
-
221
- @pytest.mark.asyncio
222
- async def test_base_models_async_pager(client):
223
- pager = await client.aio.models.list(config={'page_size': 10})
224
-
225
- assert pager.name == 'models'
226
- assert pager.page_size == 10
227
- assert len(pager) <= 10
228
-
229
- # Iterate through all the pages. Then next_page() should raise an exception.
230
- async for _ in pager:
231
- pass
232
- with pytest.raises(IndexError, match='No more pages to fetch.'):
233
- await pager.next_page()
@@ -1,189 +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 recontext_image."""
18
-
19
- import pytest
20
-
21
- from ... import types
22
- from .. import pytest_helper
23
-
24
- PRODUCT_RECONTEXT_MODEL_LATEST = 'imagen-product-recontext-preview-06-30'
25
-
26
- VIRTUAL_TRY_ON_IMAGE_MODEL_LATEST = 'virtual-try-on-preview-08-04'
27
-
28
- BACKPACK1 = types.Image(
29
- gcs_uri='gs://genai-sdk-tests/inputs/images/backpack1.png',
30
- )
31
-
32
- BACKPACK2 = types.Image(
33
- gcs_uri='gs://genai-sdk-tests/inputs/images/backpack2.png',
34
- )
35
-
36
- BACKPACK3 = types.Image(
37
- gcs_uri='gs://genai-sdk-tests/inputs/images/backpack3.png',
38
- )
39
-
40
- PERSON_IMAGE = types.Image(
41
- gcs_uri='gs://genai-sdk-tests/inputs/images/man.jpg',
42
- )
43
-
44
- PANTS = types.Image(
45
- gcs_uri='gs://genai-sdk-tests/inputs/images/pants.jpg',
46
- )
47
-
48
- test_table: list[pytest_helper.TestTableItem] = [
49
- pytest_helper.TestTableItem(
50
- name='test_product_recontext',
51
- exception_if_mldev='only supported in the Vertex AI client',
52
- parameters=types._RecontextImageParameters(
53
- model=PRODUCT_RECONTEXT_MODEL_LATEST,
54
- source=types.RecontextImageSource(
55
- prompt='On a school desk',
56
- product_images=[
57
- types.ProductImage(product_image=BACKPACK1)
58
- ],
59
- ),
60
- config=types.RecontextImageConfig(
61
- number_of_images=1,
62
- add_watermark=True,
63
- output_mime_type='image/jpeg',
64
- ),
65
- ),
66
- ),
67
- pytest_helper.TestTableItem(
68
- name='test_product_recontext_all_config',
69
- exception_if_mldev='only supported in the Vertex AI client',
70
- parameters=types._RecontextImageParameters(
71
- model=PRODUCT_RECONTEXT_MODEL_LATEST,
72
- source=types.RecontextImageSource(
73
- prompt='On a school desk',
74
- product_images=[
75
- types.ProductImage(
76
- product_image=BACKPACK1,
77
- ),
78
- types.ProductImage(
79
- product_image=BACKPACK2,
80
- ),
81
- types.ProductImage(
82
- product_image=BACKPACK3,
83
- ),
84
- ],
85
- ),
86
- config=types.RecontextImageConfig(
87
- number_of_images=1,
88
- output_mime_type='image/jpeg',
89
- base_steps=32,
90
- seed=1337,
91
- add_watermark=False,
92
- safety_filter_level=types.SafetyFilterLevel.BLOCK_MEDIUM_AND_ABOVE,
93
- person_generation=types.PersonGeneration.ALLOW_ADULT,
94
- output_compression_quality=75,
95
- enhance_prompt=False,
96
- labels={'imagen_label_key': 'recontext_image'}
97
- ),
98
- ),
99
- ),
100
- pytest_helper.TestTableItem(
101
- name='test_virtual_try_on',
102
- exception_if_mldev='only supported in the Vertex AI client',
103
- parameters=types._RecontextImageParameters(
104
- model=VIRTUAL_TRY_ON_IMAGE_MODEL_LATEST,
105
- source=types.RecontextImageSource(
106
- person_image=PERSON_IMAGE,
107
- product_images=[
108
- types.ProductImage(product_image=PANTS)
109
- ],
110
- ),
111
- config=types.RecontextImageConfig(
112
- number_of_images=1,
113
- output_mime_type='image/jpeg',
114
- ),
115
- ),
116
- ),
117
- pytest_helper.TestTableItem(
118
- name='test_virtual_try_on_all_config',
119
- exception_if_mldev='only supported in the Vertex AI client',
120
- parameters=types._RecontextImageParameters(
121
- model=VIRTUAL_TRY_ON_IMAGE_MODEL_LATEST,
122
- source=types.RecontextImageSource(
123
- person_image=PERSON_IMAGE,
124
- product_images=[
125
- types.ProductImage(
126
- product_image=PANTS
127
- )
128
- ],
129
- ),
130
- config=types.RecontextImageConfig(
131
- number_of_images=1,
132
- output_mime_type='image/jpeg',
133
- base_steps=32,
134
- seed=1337,
135
- add_watermark=False,
136
- safety_filter_level=types.SafetyFilterLevel.BLOCK_MEDIUM_AND_ABOVE,
137
- person_generation=types.PersonGeneration.ALLOW_ADULT,
138
- output_compression_quality=75,
139
- enhance_prompt=False,
140
- ),
141
- ),
142
- ),
143
- ]
144
- pytestmark = pytest_helper.setup(
145
- file=__file__,
146
- globals_for_file=globals(),
147
- test_method='models.recontext_image',
148
- test_table=test_table,
149
- )
150
-
151
-
152
- @pytest.mark.asyncio
153
- async def test_product_recontext_async(client):
154
- with pytest_helper.exception_if_mldev(client, ValueError):
155
- response = await client.aio.models.recontext_image(
156
- model=PRODUCT_RECONTEXT_MODEL_LATEST,
157
- source=types.RecontextImageSource(
158
- prompt='On a school desk',
159
- product_images=[
160
- types.ProductImage(product_image=BACKPACK1)
161
- ],
162
- ),
163
- config=types.RecontextImageConfig(
164
- number_of_images=1,
165
- output_mime_type='image/jpeg',
166
- )
167
- )
168
- assert len(response.generated_images) == 1
169
- assert response.generated_images[0].image.image_bytes
170
-
171
-
172
- @pytest.mark.asyncio
173
- async def test_virtual_try_on_async(client):
174
- with pytest_helper.exception_if_mldev(client, ValueError):
175
- response = await client.aio.models.recontext_image(
176
- model=VIRTUAL_TRY_ON_IMAGE_MODEL_LATEST,
177
- source=types.RecontextImageSource(
178
- person_image=PERSON_IMAGE,
179
- product_images=[
180
- types.ProductImage(product_image=PANTS)
181
- ],
182
- ),
183
- config=types.RecontextImageConfig(
184
- number_of_images=1,
185
- output_mime_type='image/jpeg',
186
- ),
187
- )
188
- assert len(response.generated_images) == 1
189
- assert response.generated_images[0].image.image_bytes
@@ -1,148 +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 segment_image."""
18
-
19
- import os
20
-
21
- import pytest
22
-
23
- from ... import types
24
- from .. import pytest_helper
25
-
26
- SEGMENT_IMAGE_MODEL_LATEST = 'image-segmentation-001'
27
-
28
- SOURCE_IMAGE_FILE_PATH1 = os.path.abspath(
29
- os.path.join(os.path.dirname(__file__), '../data/google.png')
30
- )
31
-
32
- SOURCE_IMAGE1 = types.Image.from_file(location=SOURCE_IMAGE_FILE_PATH1)
33
-
34
- SOURCE_IMAGE_FILE_PATH2 = os.path.abspath(
35
- os.path.join(os.path.dirname(__file__), '../data/skateboard_stop_sign.jpg')
36
- )
37
-
38
- SOURCE_IMAGE2 = types.Image.from_file(location=SOURCE_IMAGE_FILE_PATH2)
39
-
40
- SCRIBBLE_IMAGE_FILE_PATH = os.path.abspath(
41
- os.path.join(os.path.dirname(__file__), '../data/segmentation_scribble.jpg')
42
- )
43
-
44
- SCRIBBLE_IMAGE = types.Image.from_file(location=SCRIBBLE_IMAGE_FILE_PATH)
45
-
46
- test_table: list[pytest_helper.TestTableItem] = [
47
- pytest_helper.TestTableItem(
48
- name='test_segment_foreground',
49
- exception_if_mldev='only supported in the Vertex AI client',
50
- parameters=types._SegmentImageParameters(
51
- model=SEGMENT_IMAGE_MODEL_LATEST,
52
- source=types.SegmentImageSource(
53
- image=SOURCE_IMAGE1,
54
- ),
55
- config=types.SegmentImageConfig(
56
- mode=types.SegmentMode.FOREGROUND,
57
- max_predictions=1,
58
- confidence_threshold=0.02,
59
- mask_dilation=0.02,
60
- binary_color_threshold=98,
61
- labels={'imagen_label_key': 'segment_image'}
62
- ),
63
- ),
64
- ),
65
- pytest_helper.TestTableItem(
66
- name='test_segment_background',
67
- exception_if_mldev='only supported in the Vertex AI client',
68
- parameters=types._SegmentImageParameters(
69
- model=SEGMENT_IMAGE_MODEL_LATEST,
70
- source=types.SegmentImageSource(
71
- image=SOURCE_IMAGE1,
72
- ),
73
- config=types.SegmentImageConfig(
74
- mode=types.SegmentMode.BACKGROUND,
75
- ),
76
- ),
77
- ),
78
- pytest_helper.TestTableItem(
79
- name='test_segment_prompt',
80
- exception_if_mldev='only supported in the Vertex AI client',
81
- parameters=types._SegmentImageParameters(
82
- model=SEGMENT_IMAGE_MODEL_LATEST,
83
- source=types.SegmentImageSource(
84
- image=SOURCE_IMAGE1,
85
- prompt='The letter G',
86
- ),
87
- config=types.SegmentImageConfig(
88
- mode=types.SegmentMode.PROMPT,
89
- ),
90
- ),
91
- ),
92
- pytest_helper.TestTableItem(
93
- name='test_segment_semantic',
94
- exception_if_mldev='only supported in the Vertex AI client',
95
- parameters=types._SegmentImageParameters(
96
- model=SEGMENT_IMAGE_MODEL_LATEST,
97
- source=types.SegmentImageSource(
98
- image=SOURCE_IMAGE2,
99
- prompt='skateboard',
100
- ),
101
- config=types.SegmentImageConfig(
102
- mode=types.SegmentMode.SEMANTIC,
103
- ),
104
- ),
105
- ),
106
- pytest_helper.TestTableItem(
107
- name='test_segment_interactive',
108
- exception_if_mldev='only supported in the Vertex AI client',
109
- parameters=types._SegmentImageParameters(
110
- model=SEGMENT_IMAGE_MODEL_LATEST,
111
- source=types.SegmentImageSource(
112
- image=SOURCE_IMAGE2,
113
- scribble_image=types.ScribbleImage(image=SCRIBBLE_IMAGE),
114
- ),
115
- config=types.SegmentImageConfig(
116
- mode=types.SegmentMode.INTERACTIVE,
117
- ),
118
- ),
119
- ),
120
- ]
121
- pytestmark = pytest_helper.setup(
122
- file=__file__,
123
- globals_for_file=globals(),
124
- test_method='models.segment_image',
125
- test_table=test_table,
126
- )
127
-
128
-
129
- @pytest.mark.asyncio
130
- async def test_segment_foreground_async(client):
131
- with pytest_helper.exception_if_mldev(client, ValueError):
132
- response = await client.aio.models.segment_image(
133
- model=SEGMENT_IMAGE_MODEL_LATEST,
134
- source=types.SegmentImageSource(
135
- image=SOURCE_IMAGE2,
136
- ),
137
- config=types.SegmentImageConfig(
138
- mode=types.SegmentMode.FOREGROUND,
139
- max_predictions=1,
140
- confidence_threshold=0.02,
141
- mask_dilation=0.02,
142
- binary_color_threshold=98,
143
- )
144
- )
145
- assert response.generated_masks[0].mask.image_bytes
146
- assert len(response.generated_masks) == 1
147
- assert response.generated_masks[0].labels[0].label == 'foreground'
148
- assert response.generated_masks[0].labels[0].score > 0