google-adk 0.0.2__py3-none-any.whl → 0.0.4__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 (153) hide show
  1. google/adk/agents/run_config.py +4 -0
  2. google/adk/auth/auth_preprocessor.py +19 -16
  3. google/adk/cli/agent_graph.py +31 -5
  4. google/adk/cli/browser/index.html +1 -1
  5. google/adk/cli/browser/{main-XUU6OGCC.js → main-CU22TRPI.js} +30 -30
  6. google/adk/cli/cli.py +8 -8
  7. google/adk/cli/cli_deploy.py +2 -4
  8. google/adk/cli/cli_tools_click.py +57 -12
  9. google/adk/cli/fast_api.py +19 -9
  10. google/adk/flows/llm_flows/contents.py +21 -1
  11. google/adk/flows/llm_flows/functions.py +3 -1
  12. google/adk/models/google_llm.py +0 -1
  13. google/adk/runners.py +13 -2
  14. google/adk/version.py +1 -1
  15. {google_adk-0.0.2.dist-info → google_adk-0.0.4.dist-info}/METADATA +4 -2
  16. google_adk-0.0.4.dist-info/RECORD +175 -0
  17. {google_adk-0.0.2.dist-info → google_adk-0.0.4.dist-info}/WHEEL +1 -1
  18. google/adk/cli/media_streamer/__init__.py +0 -19
  19. google/adk/cli/media_streamer/index.html +0 -228
  20. google/adk/tests/__init__.py +0 -14
  21. google/adk/tests/integration/.env.example +0 -10
  22. google/adk/tests/integration/__init__.py +0 -18
  23. google/adk/tests/integration/conftest.py +0 -119
  24. google/adk/tests/integration/fixture/__init__.py +0 -14
  25. google/adk/tests/integration/fixture/agent_with_config/__init__.py +0 -15
  26. google/adk/tests/integration/fixture/agent_with_config/agent.py +0 -88
  27. google/adk/tests/integration/fixture/callback_agent/__init__.py +0 -15
  28. google/adk/tests/integration/fixture/callback_agent/agent.py +0 -105
  29. google/adk/tests/integration/fixture/context_update_test/OWNERS +0 -1
  30. google/adk/tests/integration/fixture/context_update_test/__init__.py +0 -15
  31. google/adk/tests/integration/fixture/context_update_test/agent.py +0 -43
  32. google/adk/tests/integration/fixture/context_update_test/successful_test.session.json +0 -582
  33. google/adk/tests/integration/fixture/context_variable_agent/__init__.py +0 -15
  34. google/adk/tests/integration/fixture/context_variable_agent/agent.py +0 -115
  35. google/adk/tests/integration/fixture/customer_support_ma/__init__.py +0 -15
  36. google/adk/tests/integration/fixture/customer_support_ma/agent.py +0 -172
  37. google/adk/tests/integration/fixture/ecommerce_customer_service_agent/__init__.py +0 -15
  38. google/adk/tests/integration/fixture/ecommerce_customer_service_agent/agent.py +0 -338
  39. google/adk/tests/integration/fixture/ecommerce_customer_service_agent/order_query.test.json +0 -69
  40. google/adk/tests/integration/fixture/ecommerce_customer_service_agent/test_config.json +0 -6
  41. google/adk/tests/integration/fixture/flow_complex_spark/__init__.py +0 -15
  42. google/adk/tests/integration/fixture/flow_complex_spark/agent.py +0 -182
  43. google/adk/tests/integration/fixture/flow_complex_spark/sample.debug.log +0 -243
  44. google/adk/tests/integration/fixture/flow_complex_spark/sample.session.json +0 -190
  45. google/adk/tests/integration/fixture/hello_world_agent/__init__.py +0 -15
  46. google/adk/tests/integration/fixture/hello_world_agent/agent.py +0 -95
  47. google/adk/tests/integration/fixture/hello_world_agent/roll_die.test.json +0 -24
  48. google/adk/tests/integration/fixture/hello_world_agent/test_config.json +0 -6
  49. google/adk/tests/integration/fixture/home_automation_agent/__init__.py +0 -15
  50. google/adk/tests/integration/fixture/home_automation_agent/agent.py +0 -304
  51. google/adk/tests/integration/fixture/home_automation_agent/simple_test.test.json +0 -5
  52. google/adk/tests/integration/fixture/home_automation_agent/simple_test2.test.json +0 -5
  53. google/adk/tests/integration/fixture/home_automation_agent/test_config.json +0 -5
  54. google/adk/tests/integration/fixture/home_automation_agent/test_files/dependent_tool_calls.test.json +0 -18
  55. google/adk/tests/integration/fixture/home_automation_agent/test_files/memorizing_past_events/eval_data.test.json +0 -17
  56. google/adk/tests/integration/fixture/home_automation_agent/test_files/memorizing_past_events/test_config.json +0 -6
  57. google/adk/tests/integration/fixture/home_automation_agent/test_files/simple_multi_turn_conversation.test.json +0 -18
  58. google/adk/tests/integration/fixture/home_automation_agent/test_files/simple_test.test.json +0 -17
  59. google/adk/tests/integration/fixture/home_automation_agent/test_files/simple_test2.test.json +0 -5
  60. google/adk/tests/integration/fixture/home_automation_agent/test_files/test_config.json +0 -5
  61. google/adk/tests/integration/fixture/tool_agent/__init__.py +0 -15
  62. google/adk/tests/integration/fixture/tool_agent/agent.py +0 -218
  63. google/adk/tests/integration/fixture/tool_agent/files/Agent_test_plan.pdf +0 -0
  64. google/adk/tests/integration/fixture/trip_planner_agent/__init__.py +0 -15
  65. google/adk/tests/integration/fixture/trip_planner_agent/agent.py +0 -110
  66. google/adk/tests/integration/fixture/trip_planner_agent/initial.session.json +0 -13
  67. google/adk/tests/integration/fixture/trip_planner_agent/test_config.json +0 -5
  68. google/adk/tests/integration/fixture/trip_planner_agent/test_files/initial.session.json +0 -13
  69. google/adk/tests/integration/fixture/trip_planner_agent/test_files/test_config.json +0 -5
  70. google/adk/tests/integration/fixture/trip_planner_agent/test_files/trip_inquiry_sub_agent.test.json +0 -7
  71. google/adk/tests/integration/fixture/trip_planner_agent/trip_inquiry.test.json +0 -19
  72. google/adk/tests/integration/models/__init__.py +0 -14
  73. google/adk/tests/integration/models/test_google_llm.py +0 -65
  74. google/adk/tests/integration/test_callback.py +0 -70
  75. google/adk/tests/integration/test_context_variable.py +0 -67
  76. google/adk/tests/integration/test_evalute_agent_in_fixture.py +0 -76
  77. google/adk/tests/integration/test_multi_agent.py +0 -28
  78. google/adk/tests/integration/test_multi_turn.py +0 -42
  79. google/adk/tests/integration/test_single_agent.py +0 -23
  80. google/adk/tests/integration/test_sub_agent.py +0 -26
  81. google/adk/tests/integration/test_system_instruction.py +0 -177
  82. google/adk/tests/integration/test_tools.py +0 -287
  83. google/adk/tests/integration/test_with_test_file.py +0 -34
  84. google/adk/tests/integration/tools/__init__.py +0 -14
  85. google/adk/tests/integration/utils/__init__.py +0 -16
  86. google/adk/tests/integration/utils/asserts.py +0 -75
  87. google/adk/tests/integration/utils/test_runner.py +0 -97
  88. google/adk/tests/unittests/__init__.py +0 -14
  89. google/adk/tests/unittests/agents/__init__.py +0 -14
  90. google/adk/tests/unittests/agents/test_base_agent.py +0 -407
  91. google/adk/tests/unittests/agents/test_langgraph_agent.py +0 -191
  92. google/adk/tests/unittests/agents/test_llm_agent_callbacks.py +0 -138
  93. google/adk/tests/unittests/agents/test_llm_agent_fields.py +0 -231
  94. google/adk/tests/unittests/agents/test_loop_agent.py +0 -136
  95. google/adk/tests/unittests/agents/test_parallel_agent.py +0 -92
  96. google/adk/tests/unittests/agents/test_sequential_agent.py +0 -114
  97. google/adk/tests/unittests/artifacts/__init__.py +0 -14
  98. google/adk/tests/unittests/artifacts/test_artifact_service.py +0 -276
  99. google/adk/tests/unittests/auth/test_auth_handler.py +0 -575
  100. google/adk/tests/unittests/conftest.py +0 -73
  101. google/adk/tests/unittests/fast_api/__init__.py +0 -14
  102. google/adk/tests/unittests/fast_api/test_fast_api.py +0 -269
  103. google/adk/tests/unittests/flows/__init__.py +0 -14
  104. google/adk/tests/unittests/flows/llm_flows/__init__.py +0 -14
  105. google/adk/tests/unittests/flows/llm_flows/_test_examples.py +0 -142
  106. google/adk/tests/unittests/flows/llm_flows/test_agent_transfer.py +0 -311
  107. google/adk/tests/unittests/flows/llm_flows/test_functions_long_running.py +0 -244
  108. google/adk/tests/unittests/flows/llm_flows/test_functions_request_euc.py +0 -346
  109. google/adk/tests/unittests/flows/llm_flows/test_functions_sequential.py +0 -93
  110. google/adk/tests/unittests/flows/llm_flows/test_functions_simple.py +0 -258
  111. google/adk/tests/unittests/flows/llm_flows/test_identity.py +0 -66
  112. google/adk/tests/unittests/flows/llm_flows/test_instructions.py +0 -164
  113. google/adk/tests/unittests/flows/llm_flows/test_model_callbacks.py +0 -142
  114. google/adk/tests/unittests/flows/llm_flows/test_other_configs.py +0 -46
  115. google/adk/tests/unittests/flows/llm_flows/test_tool_callbacks.py +0 -269
  116. google/adk/tests/unittests/models/__init__.py +0 -14
  117. google/adk/tests/unittests/models/test_google_llm.py +0 -224
  118. google/adk/tests/unittests/models/test_litellm.py +0 -804
  119. google/adk/tests/unittests/models/test_models.py +0 -60
  120. google/adk/tests/unittests/sessions/__init__.py +0 -14
  121. google/adk/tests/unittests/sessions/test_session_service.py +0 -227
  122. google/adk/tests/unittests/sessions/test_vertex_ai_session_service.py +0 -246
  123. google/adk/tests/unittests/streaming/__init__.py +0 -14
  124. google/adk/tests/unittests/streaming/test_streaming.py +0 -50
  125. google/adk/tests/unittests/tools/__init__.py +0 -14
  126. google/adk/tests/unittests/tools/apihub_tool/clients/test_apihub_client.py +0 -499
  127. google/adk/tests/unittests/tools/apihub_tool/test_apihub_toolset.py +0 -204
  128. google/adk/tests/unittests/tools/application_integration_tool/clients/test_connections_client.py +0 -600
  129. google/adk/tests/unittests/tools/application_integration_tool/clients/test_integration_client.py +0 -630
  130. google/adk/tests/unittests/tools/application_integration_tool/test_application_integration_toolset.py +0 -345
  131. google/adk/tests/unittests/tools/google_api_tool/__init__.py +0 -13
  132. google/adk/tests/unittests/tools/google_api_tool/test_googleapi_to_openapi_converter.py +0 -657
  133. google/adk/tests/unittests/tools/openapi_tool/auth/credential_exchangers/test_auto_auth_credential_exchanger.py +0 -145
  134. google/adk/tests/unittests/tools/openapi_tool/auth/credential_exchangers/test_base_auth_credential_exchanger.py +0 -68
  135. google/adk/tests/unittests/tools/openapi_tool/auth/credential_exchangers/test_oauth2_exchanger.py +0 -153
  136. google/adk/tests/unittests/tools/openapi_tool/auth/credential_exchangers/test_service_account_exchanger.py +0 -196
  137. google/adk/tests/unittests/tools/openapi_tool/auth/test_auth_helper.py +0 -573
  138. google/adk/tests/unittests/tools/openapi_tool/common/test_common.py +0 -436
  139. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test.yaml +0 -1367
  140. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test_openapi_spec_parser.py +0 -628
  141. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test_openapi_toolset.py +0 -139
  142. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test_operation_parser.py +0 -406
  143. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test_rest_api_tool.py +0 -966
  144. google/adk/tests/unittests/tools/openapi_tool/openapi_spec_parser/test_tool_auth_handler.py +0 -201
  145. google/adk/tests/unittests/tools/retrieval/__init__.py +0 -14
  146. google/adk/tests/unittests/tools/retrieval/test_vertex_ai_rag_retrieval.py +0 -147
  147. google/adk/tests/unittests/tools/test_agent_tool.py +0 -167
  148. google/adk/tests/unittests/tools/test_base_tool.py +0 -141
  149. google/adk/tests/unittests/tools/test_build_function_declaration.py +0 -277
  150. google/adk/tests/unittests/utils.py +0 -304
  151. google_adk-0.0.2.dist-info/RECORD +0 -308
  152. {google_adk-0.0.2.dist-info → google_adk-0.0.4.dist-info}/entry_points.txt +0 -0
  153. {google_adk-0.0.2.dist-info → google_adk-0.0.4.dist-info/licenses}/LICENSE +0 -0
@@ -1,436 +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
- from typing import Any
16
- from typing import Dict
17
- from typing import List
18
-
19
- from fastapi.openapi.models import Response, Schema
20
- from google.adk.tools.openapi_tool.common.common import ApiParameter
21
- from google.adk.tools.openapi_tool.common.common import PydocHelper
22
- from google.adk.tools.openapi_tool.common.common import rename_python_keywords
23
- from google.adk.tools.openapi_tool.common.common import to_snake_case
24
- from google.adk.tools.openapi_tool.common.common import TypeHintHelper
25
- import pytest
26
-
27
-
28
- def dict_to_responses(input: Dict[str, Any]) -> Dict[str, Response]:
29
- return {k: Response.model_validate(input[k]) for k in input}
30
-
31
-
32
- class TestToSnakeCase:
33
-
34
- @pytest.mark.parametrize(
35
- 'input_str, expected_output',
36
- [
37
- ('lowerCamelCase', 'lower_camel_case'),
38
- ('UpperCamelCase', 'upper_camel_case'),
39
- ('space separated', 'space_separated'),
40
- ('REST API', 'rest_api'),
41
- ('Mixed_CASE with_Spaces', 'mixed_case_with_spaces'),
42
- ('__init__', 'init'),
43
- ('APIKey', 'api_key'),
44
- ('SomeLongURL', 'some_long_url'),
45
- ('CONSTANT_CASE', 'constant_case'),
46
- ('already_snake_case', 'already_snake_case'),
47
- ('single', 'single'),
48
- ('', ''),
49
- (' spaced ', 'spaced'),
50
- ('with123numbers', 'with123numbers'),
51
- ('With_Mixed_123_and_SPACES', 'with_mixed_123_and_spaces'),
52
- ('HTMLParser', 'html_parser'),
53
- ('HTTPResponseCode', 'http_response_code'),
54
- ('a_b_c', 'a_b_c'),
55
- ('A_B_C', 'a_b_c'),
56
- ('fromAtoB', 'from_ato_b'),
57
- ('XMLHTTPRequest', 'xmlhttp_request'),
58
- ('_leading', 'leading'),
59
- ('trailing_', 'trailing'),
60
- (' leading_and_trailing_ ', 'leading_and_trailing'),
61
- ('Multiple___Underscores', 'multiple_underscores'),
62
- (' spaces_and___underscores ', 'spaces_and_underscores'),
63
- (' _mixed_Case ', 'mixed_case'),
64
- ('123Start', '123_start'),
65
- ('End123', 'end123'),
66
- ('Mid123dle', 'mid123dle'),
67
- ],
68
- )
69
- def test_to_snake_case(self, input_str, expected_output):
70
- assert to_snake_case(input_str) == expected_output
71
-
72
-
73
- class TestRenamePythonKeywords:
74
-
75
- @pytest.mark.parametrize(
76
- 'input_str, expected_output',
77
- [
78
- ('in', 'param_in'),
79
- ('for', 'param_for'),
80
- ('class', 'param_class'),
81
- ('normal', 'normal'),
82
- ('param_if', 'param_if'),
83
- ('', ''),
84
- ],
85
- )
86
- def test_rename_python_keywords(self, input_str, expected_output):
87
- assert rename_python_keywords(input_str) == expected_output
88
-
89
-
90
- class TestApiParameter:
91
-
92
- def test_api_parameter_initialization(self):
93
- schema = Schema(type='string', description='A string parameter')
94
- param = ApiParameter(
95
- original_name='testParam',
96
- description='A string description',
97
- param_location='query',
98
- param_schema=schema,
99
- )
100
- assert param.original_name == 'testParam'
101
- assert param.param_location == 'query'
102
- assert param.param_schema.type == 'string'
103
- assert param.param_schema.description == 'A string parameter'
104
- assert param.py_name == 'test_param'
105
- assert param.type_hint == 'str'
106
- assert param.type_value == str
107
- assert param.description == 'A string description'
108
-
109
- def test_api_parameter_keyword_rename(self):
110
- schema = Schema(type='string')
111
- param = ApiParameter(
112
- original_name='in',
113
- param_location='query',
114
- param_schema=schema,
115
- )
116
- assert param.py_name == 'param_in'
117
-
118
- def test_api_parameter_custom_py_name(self):
119
- schema = Schema(type='integer')
120
- param = ApiParameter(
121
- original_name='testParam',
122
- param_location='query',
123
- param_schema=schema,
124
- py_name='custom_name',
125
- )
126
- assert param.py_name == 'custom_name'
127
-
128
- def test_api_parameter_str_representation(self):
129
- schema = Schema(type='number')
130
- param = ApiParameter(
131
- original_name='testParam',
132
- param_location='query',
133
- param_schema=schema,
134
- )
135
- assert str(param) == 'test_param: float'
136
-
137
- def test_api_parameter_to_arg_string(self):
138
- schema = Schema(type='boolean')
139
- param = ApiParameter(
140
- original_name='testParam',
141
- param_location='query',
142
- param_schema=schema,
143
- )
144
- assert param.to_arg_string() == 'test_param=test_param'
145
-
146
- def test_api_parameter_to_dict_property(self):
147
- schema = Schema(type='string')
148
- param = ApiParameter(
149
- original_name='testParam',
150
- param_location='path',
151
- param_schema=schema,
152
- )
153
- assert param.to_dict_property() == '"test_param": test_param'
154
-
155
- def test_api_parameter_model_serializer(self):
156
- schema = Schema(type='string', description='test description')
157
- param = ApiParameter(
158
- original_name='TestParam',
159
- param_location='path',
160
- param_schema=schema,
161
- py_name='test_param_custom',
162
- description='test description',
163
- )
164
-
165
- serialized_param = param.model_dump(mode='json', exclude_none=True)
166
-
167
- assert serialized_param == {
168
- 'original_name': 'TestParam',
169
- 'param_location': 'path',
170
- 'param_schema': {'type': 'string', 'description': 'test description'},
171
- 'description': 'test description',
172
- 'py_name': 'test_param_custom',
173
- }
174
-
175
- @pytest.mark.parametrize(
176
- 'schema, expected_type_value, expected_type_hint',
177
- [
178
- ({'type': 'integer'}, int, 'int'),
179
- ({'type': 'number'}, float, 'float'),
180
- ({'type': 'boolean'}, bool, 'bool'),
181
- ({'type': 'string'}, str, 'str'),
182
- (
183
- {'type': 'string', 'format': 'date'},
184
- str,
185
- 'str',
186
- ),
187
- (
188
- {'type': 'string', 'format': 'date-time'},
189
- str,
190
- 'str',
191
- ),
192
- (
193
- {'type': 'array', 'items': {'type': 'integer'}},
194
- List[int],
195
- 'List[int]',
196
- ),
197
- (
198
- {'type': 'array', 'items': {'type': 'string'}},
199
- List[str],
200
- 'List[str]',
201
- ),
202
- (
203
- {
204
- 'type': 'array',
205
- 'items': {'type': 'object'},
206
- },
207
- List[Dict[str, Any]],
208
- 'List[Dict[str, Any]]',
209
- ),
210
- ({'type': 'object'}, Dict[str, Any], 'Dict[str, Any]'),
211
- ({'type': 'unknown'}, Any, 'Any'),
212
- ({}, Any, 'Any'),
213
- ],
214
- )
215
- def test_api_parameter_type_hint_helper(
216
- self, schema, expected_type_value, expected_type_hint
217
- ):
218
- param = ApiParameter(
219
- original_name='test', param_location='query', param_schema=schema
220
- )
221
- assert param.type_value == expected_type_value
222
- assert param.type_hint == expected_type_hint
223
- assert (
224
- TypeHintHelper.get_type_hint(param.param_schema) == expected_type_hint
225
- )
226
- assert (
227
- TypeHintHelper.get_type_value(param.param_schema) == expected_type_value
228
- )
229
-
230
- def test_api_parameter_description(self):
231
- schema = Schema(type='string')
232
- param = ApiParameter(
233
- original_name='param1',
234
- param_location='query',
235
- param_schema=schema,
236
- description='The description',
237
- )
238
- assert param.description == 'The description'
239
-
240
- def test_api_parameter_description_use_schema_fallback(self):
241
- schema = Schema(type='string', description='The description')
242
- param = ApiParameter(
243
- original_name='param1',
244
- param_location='query',
245
- param_schema=schema,
246
- )
247
- assert param.description == 'The description'
248
-
249
-
250
- class TestTypeHintHelper:
251
-
252
- @pytest.mark.parametrize(
253
- 'schema, expected_type_value, expected_type_hint',
254
- [
255
- ({'type': 'integer'}, int, 'int'),
256
- ({'type': 'number'}, float, 'float'),
257
- ({'type': 'string'}, str, 'str'),
258
- (
259
- {
260
- 'type': 'array',
261
- 'items': {'type': 'string'},
262
- },
263
- List[str],
264
- 'List[str]',
265
- ),
266
- ],
267
- )
268
- def test_get_type_value_and_hint(
269
- self, schema, expected_type_value, expected_type_hint
270
- ):
271
-
272
- param = ApiParameter(
273
- original_name='test_param',
274
- param_location='query',
275
- param_schema=schema,
276
- description='Test parameter',
277
- )
278
- assert (
279
- TypeHintHelper.get_type_value(param.param_schema) == expected_type_value
280
- )
281
- assert (
282
- TypeHintHelper.get_type_hint(param.param_schema) == expected_type_hint
283
- )
284
-
285
-
286
- class TestPydocHelper:
287
-
288
- def test_generate_param_doc_simple(self):
289
- schema = Schema(type='string')
290
- param = ApiParameter(
291
- original_name='test_param',
292
- param_location='query',
293
- param_schema=schema,
294
- description='Test description',
295
- )
296
-
297
- expected_doc = 'test_param (str): Test description'
298
- assert PydocHelper.generate_param_doc(param) == expected_doc
299
-
300
- def test_generate_param_doc_no_description(self):
301
- schema = Schema(type='integer')
302
- param = ApiParameter(
303
- original_name='test_param',
304
- param_location='query',
305
- param_schema=schema,
306
- )
307
- expected_doc = 'test_param (int): '
308
- assert PydocHelper.generate_param_doc(param) == expected_doc
309
-
310
- def test_generate_param_doc_object(self):
311
- schema = Schema(
312
- type='object',
313
- properties={
314
- 'prop1': {'type': 'string', 'description': 'Prop1 desc'},
315
- 'prop2': {'type': 'integer'},
316
- },
317
- )
318
- param = ApiParameter(
319
- original_name='test_param',
320
- param_location='query',
321
- param_schema=schema,
322
- description='Test object parameter',
323
- )
324
- expected_doc = (
325
- 'test_param (Dict[str, Any]): Test object parameter Object'
326
- ' properties:\n prop1 (str): Prop1 desc\n prop2'
327
- ' (int): \n'
328
- )
329
- assert PydocHelper.generate_param_doc(param) == expected_doc
330
-
331
- def test_generate_param_doc_object_no_properties(self):
332
- schema = Schema(type='object', description='A test schema')
333
- param = ApiParameter(
334
- original_name='test_param',
335
- param_location='query',
336
- param_schema=schema,
337
- description='The description.',
338
- )
339
- expected_doc = 'test_param (Dict[str, Any]): The description.'
340
- assert PydocHelper.generate_param_doc(param) == expected_doc
341
-
342
- def test_generate_return_doc_simple(self):
343
- responses = {
344
- '200': {
345
- 'description': 'Successful response',
346
- 'content': {'application/json': {'schema': {'type': 'string'}}},
347
- }
348
- }
349
- expected_doc = 'Returns (str): Successful response'
350
- assert (
351
- PydocHelper.generate_return_doc(dict_to_responses(responses))
352
- == expected_doc
353
- )
354
-
355
- def test_generate_return_doc_no_content(self):
356
- responses = {'204': {'description': 'No content'}}
357
- assert not PydocHelper.generate_return_doc(dict_to_responses(responses))
358
-
359
- def test_generate_return_doc_object(self):
360
- responses = {
361
- '200': {
362
- 'description': 'Successful object response',
363
- 'content': {
364
- 'application/json': {
365
- 'schema': {
366
- 'type': 'object',
367
- 'properties': {
368
- 'prop1': {
369
- 'type': 'string',
370
- 'description': 'Prop1 desc',
371
- },
372
- 'prop2': {'type': 'integer'},
373
- },
374
- }
375
- }
376
- },
377
- }
378
- }
379
-
380
- return_doc = PydocHelper.generate_return_doc(dict_to_responses(responses))
381
-
382
- assert 'Returns (Dict[str, Any]): Successful object response' in return_doc
383
- assert 'prop1 (str): Prop1 desc' in return_doc
384
- assert 'prop2 (int):' in return_doc
385
-
386
- def test_generate_return_doc_multiple_success(self):
387
- responses = {
388
- '200': {
389
- 'description': 'Successful response',
390
- 'content': {'application/json': {'schema': {'type': 'string'}}},
391
- },
392
- '400': {'description': 'Bad request'},
393
- }
394
- expected_doc = 'Returns (str): Successful response'
395
- assert (
396
- PydocHelper.generate_return_doc(dict_to_responses(responses))
397
- == expected_doc
398
- )
399
-
400
- def test_generate_return_doc_2xx_smallest_status_code_response(self):
401
- responses = {
402
- '201': {
403
- 'description': '201 response',
404
- 'content': {'application/json': {'schema': {'type': 'integer'}}},
405
- },
406
- '200': {
407
- 'description': '200 response',
408
- 'content': {'application/json': {'schema': {'type': 'string'}}},
409
- },
410
- '400': {'description': 'Bad request'},
411
- }
412
-
413
- expected_doc = 'Returns (str): 200 response'
414
- assert (
415
- PydocHelper.generate_return_doc(dict_to_responses(responses))
416
- == expected_doc
417
- )
418
-
419
- def test_generate_return_doc_contentful_response(self):
420
- responses = {
421
- '200': {'description': 'No content response'},
422
- '201': {
423
- 'description': '201 response',
424
- 'content': {'application/json': {'schema': {'type': 'string'}}},
425
- },
426
- '400': {'description': 'Bad request'},
427
- }
428
- expected_doc = 'Returns (str): 201 response'
429
- assert (
430
- PydocHelper.generate_return_doc(dict_to_responses(responses))
431
- == expected_doc
432
- )
433
-
434
-
435
- if __name__ == '__main__':
436
- pytest.main([__file__])