vellum-ai 0.14.41__py3-none-any.whl → 1.11.2__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.

Potentially problematic release.


This version of vellum-ai might be problematic. Click here for more details.

Files changed (1326) hide show
  1. vellum/__init__.py +281 -8
  2. vellum/client/README.md +70 -17
  3. vellum/client/__init__.py +598 -1371
  4. vellum/client/core/__init__.py +5 -0
  5. vellum/client/core/api_error.py +13 -5
  6. vellum/client/core/client_wrapper.py +31 -5
  7. vellum/client/core/file.py +13 -8
  8. vellum/client/core/force_multipart.py +16 -0
  9. vellum/client/core/http_client.py +76 -20
  10. vellum/client/core/http_response.py +55 -0
  11. vellum/client/core/jsonable_encoder.py +0 -1
  12. vellum/client/core/pydantic_utilities.py +95 -119
  13. vellum/client/core/request_options.py +3 -0
  14. vellum/client/core/serialization.py +7 -3
  15. vellum/client/errors/__init__.py +14 -1
  16. vellum/client/errors/bad_request_error.py +4 -3
  17. vellum/client/errors/forbidden_error.py +4 -3
  18. vellum/client/errors/internal_server_error.py +4 -3
  19. vellum/client/errors/misdirected_request_error.py +11 -0
  20. vellum/client/errors/not_found_error.py +4 -3
  21. vellum/client/errors/too_many_requests_error.py +11 -0
  22. vellum/client/errors/unauthorized_error.py +11 -0
  23. vellum/client/raw_client.py +2725 -0
  24. vellum/client/reference.md +2489 -1038
  25. vellum/client/resources/__init__.py +16 -2
  26. vellum/client/resources/ad_hoc/__init__.py +2 -0
  27. vellum/client/resources/ad_hoc/client.py +173 -365
  28. vellum/client/resources/ad_hoc/raw_client.py +569 -0
  29. vellum/client/resources/container_images/__init__.py +2 -0
  30. vellum/client/resources/container_images/client.py +72 -185
  31. vellum/client/resources/container_images/raw_client.py +407 -0
  32. vellum/client/resources/deployments/__init__.py +2 -0
  33. vellum/client/resources/deployments/client.py +211 -424
  34. vellum/client/resources/deployments/raw_client.py +1002 -0
  35. vellum/client/resources/deployments/types/__init__.py +2 -0
  36. vellum/client/resources/document_indexes/__init__.py +2 -0
  37. vellum/client/resources/document_indexes/client.py +131 -365
  38. vellum/client/resources/document_indexes/raw_client.py +866 -0
  39. vellum/client/resources/document_indexes/types/__init__.py +2 -0
  40. vellum/client/resources/documents/__init__.py +2 -0
  41. vellum/client/resources/documents/client.py +93 -325
  42. vellum/client/resources/documents/raw_client.py +662 -0
  43. vellum/client/resources/{release_reviews → environments}/__init__.py +2 -0
  44. vellum/client/resources/environments/client.py +106 -0
  45. vellum/client/resources/environments/raw_client.py +95 -0
  46. vellum/client/resources/events/__init__.py +4 -0
  47. vellum/client/resources/events/client.py +201 -0
  48. vellum/client/resources/events/raw_client.py +211 -0
  49. vellum/client/resources/folder_entities/__init__.py +2 -0
  50. vellum/client/resources/folder_entities/client.py +56 -89
  51. vellum/client/resources/folder_entities/raw_client.py +276 -0
  52. vellum/client/resources/folder_entities/types/__init__.py +2 -0
  53. vellum/client/resources/integration_auth_configs/__init__.py +4 -0
  54. vellum/client/resources/integration_auth_configs/client.py +186 -0
  55. vellum/client/resources/integration_auth_configs/raw_client.py +171 -0
  56. vellum/client/resources/integration_providers/__init__.py +4 -0
  57. vellum/client/resources/integration_providers/client.py +299 -0
  58. vellum/client/resources/integration_providers/raw_client.py +275 -0
  59. vellum/client/resources/integrations/__init__.py +4 -0
  60. vellum/client/resources/integrations/client.py +466 -0
  61. vellum/client/resources/integrations/raw_client.py +557 -0
  62. vellum/client/resources/metric_definitions/__init__.py +2 -0
  63. vellum/client/resources/metric_definitions/client.py +60 -100
  64. vellum/client/resources/metric_definitions/raw_client.py +224 -0
  65. vellum/client/resources/ml_models/__init__.py +2 -0
  66. vellum/client/resources/ml_models/client.py +37 -46
  67. vellum/client/resources/ml_models/raw_client.py +102 -0
  68. vellum/client/resources/organizations/__init__.py +2 -0
  69. vellum/client/resources/organizations/client.py +37 -45
  70. vellum/client/resources/organizations/raw_client.py +95 -0
  71. vellum/client/resources/prompts/__init__.py +2 -0
  72. vellum/client/resources/prompts/client.py +210 -95
  73. vellum/client/resources/prompts/raw_client.py +353 -0
  74. vellum/client/resources/sandboxes/__init__.py +2 -0
  75. vellum/client/resources/sandboxes/client.py +69 -147
  76. vellum/client/resources/sandboxes/raw_client.py +392 -0
  77. vellum/client/resources/test_suite_runs/__init__.py +2 -0
  78. vellum/client/resources/test_suite_runs/client.py +65 -151
  79. vellum/client/resources/test_suite_runs/raw_client.py +354 -0
  80. vellum/client/resources/test_suites/__init__.py +2 -0
  81. vellum/client/resources/test_suites/client.py +162 -266
  82. vellum/client/resources/test_suites/raw_client.py +530 -0
  83. vellum/client/resources/uploaded_files/__init__.py +4 -0
  84. vellum/client/resources/uploaded_files/client.py +230 -0
  85. vellum/client/resources/uploaded_files/raw_client.py +316 -0
  86. vellum/client/resources/workflow_deployments/__init__.py +2 -0
  87. vellum/client/resources/workflow_deployments/client.py +312 -355
  88. vellum/client/resources/workflow_deployments/raw_client.py +1059 -0
  89. vellum/client/resources/workflow_deployments/types/__init__.py +2 -0
  90. vellum/client/resources/workflow_executions/__init__.py +4 -0
  91. vellum/client/resources/workflow_executions/client.py +140 -0
  92. vellum/client/resources/workflow_executions/raw_client.py +173 -0
  93. vellum/client/resources/workflow_sandboxes/__init__.py +2 -0
  94. vellum/client/resources/workflow_sandboxes/client.py +58 -117
  95. vellum/client/resources/workflow_sandboxes/raw_client.py +291 -0
  96. vellum/client/resources/workflow_sandboxes/types/__init__.py +2 -0
  97. vellum/client/resources/workflows/__init__.py +2 -0
  98. vellum/client/resources/workflows/client.py +258 -141
  99. vellum/client/resources/workflows/raw_client.py +547 -0
  100. vellum/client/resources/workspace_secrets/__init__.py +2 -0
  101. vellum/client/resources/workspace_secrets/client.py +43 -94
  102. vellum/client/resources/workspace_secrets/raw_client.py +219 -0
  103. vellum/client/resources/workspaces/__init__.py +2 -0
  104. vellum/client/resources/workspaces/client.py +37 -45
  105. vellum/client/resources/workspaces/raw_client.py +95 -0
  106. vellum/client/tests/__init__.py +0 -0
  107. vellum/client/tests/test_utils.py +34 -0
  108. vellum/client/types/__init__.py +254 -4
  109. vellum/client/types/ad_hoc_execute_prompt_event.py +3 -2
  110. vellum/client/types/ad_hoc_expand_meta.py +2 -2
  111. vellum/client/types/ad_hoc_fulfilled_prompt_execution_meta.py +3 -3
  112. vellum/client/types/ad_hoc_initiated_prompt_execution_meta.py +2 -2
  113. vellum/client/types/ad_hoc_rejected_prompt_execution_meta.py +3 -3
  114. vellum/client/types/ad_hoc_streaming_prompt_execution_meta.py +2 -2
  115. vellum/client/types/api_actor_type_enum.py +7 -0
  116. vellum/client/types/api_node_result.py +3 -3
  117. vellum/client/types/api_node_result_data.py +4 -4
  118. vellum/client/types/api_request_parent_context.py +18 -17
  119. vellum/client/types/api_version_enum.py +1 -1
  120. vellum/client/types/array_chat_message_content.py +3 -3
  121. vellum/client/types/array_chat_message_content_item.py +7 -4
  122. vellum/client/types/array_chat_message_content_item_request.py +7 -4
  123. vellum/client/types/array_chat_message_content_request.py +3 -3
  124. vellum/client/types/array_input.py +9 -8
  125. vellum/client/types/array_vellum_value.py +4 -4
  126. vellum/client/types/array_vellum_value_request.py +4 -4
  127. vellum/client/types/audio_chat_message_content.py +3 -3
  128. vellum/client/types/audio_chat_message_content_request.py +3 -3
  129. vellum/client/types/audio_input.py +30 -0
  130. vellum/client/types/audio_input_request.py +30 -0
  131. vellum/client/types/audio_prompt_block.py +4 -4
  132. vellum/client/types/audio_vellum_value.py +3 -3
  133. vellum/client/types/audio_vellum_value_request.py +3 -3
  134. vellum/client/types/auth_type_enum.py +5 -0
  135. vellum/client/types/base_output.py +4 -4
  136. vellum/client/types/basic_vectorizer_intfloat_multilingual_e_5_large.py +2 -2
  137. vellum/client/types/basic_vectorizer_intfloat_multilingual_e_5_large_request.py +2 -2
  138. vellum/client/types/basic_vectorizer_sentence_transformers_multi_qa_mpnet_base_cos_v_1.py +2 -2
  139. vellum/client/types/basic_vectorizer_sentence_transformers_multi_qa_mpnet_base_cos_v_1_request.py +2 -2
  140. vellum/client/types/basic_vectorizer_sentence_transformers_multi_qa_mpnet_base_dot_v_1.py +2 -2
  141. vellum/client/types/basic_vectorizer_sentence_transformers_multi_qa_mpnet_base_dot_v_1_request.py +2 -2
  142. vellum/client/types/build_status_enum.py +5 -0
  143. vellum/client/types/chat_history_input.py +3 -3
  144. vellum/client/types/chat_history_input_request.py +3 -3
  145. vellum/client/types/chat_history_vellum_value.py +3 -3
  146. vellum/client/types/chat_history_vellum_value_request.py +3 -3
  147. vellum/client/types/chat_message.py +4 -4
  148. vellum/client/types/chat_message_content.py +7 -4
  149. vellum/client/types/chat_message_content_request.py +7 -4
  150. vellum/client/types/chat_message_prompt_block.py +7 -7
  151. vellum/client/types/chat_message_request.py +4 -4
  152. vellum/client/types/code_execution_node_array_result.py +8 -7
  153. vellum/client/types/code_execution_node_chat_history_result.py +3 -3
  154. vellum/client/types/code_execution_node_error_result.py +3 -3
  155. vellum/client/types/code_execution_node_function_call_result.py +3 -3
  156. vellum/client/types/code_execution_node_json_result.py +2 -2
  157. vellum/client/types/code_execution_node_number_result.py +2 -2
  158. vellum/client/types/code_execution_node_result.py +7 -6
  159. vellum/client/types/code_execution_node_result_data.py +7 -6
  160. vellum/client/types/code_execution_node_result_output.py +6 -5
  161. vellum/client/types/code_execution_node_search_results_result.py +3 -3
  162. vellum/client/types/code_execution_node_string_result.py +2 -2
  163. vellum/client/types/code_execution_package.py +3 -2
  164. vellum/client/types/code_executor_input.py +15 -6
  165. vellum/client/types/code_executor_response.py +8 -7
  166. vellum/client/types/code_executor_secret_input.py +3 -3
  167. vellum/client/types/code_resource_definition.py +3 -3
  168. vellum/client/types/compile_prompt_deployment_expand_meta_request.py +2 -2
  169. vellum/client/types/compile_prompt_meta.py +2 -2
  170. vellum/client/types/components_schemas_composio_execute_tool_request.py +5 -0
  171. vellum/client/types/components_schemas_composio_execute_tool_response.py +5 -0
  172. vellum/client/types/components_schemas_composio_integration_exec_config.py +5 -0
  173. vellum/client/types/components_schemas_composio_tool_definition.py +5 -0
  174. vellum/client/types/components_schemas_prompt_version_build_config_sandbox.py +5 -0
  175. vellum/client/types/components_schemas_slim_composio_tool_definition.py +5 -0
  176. vellum/client/types/composio_execute_tool_request.py +24 -0
  177. vellum/client/types/composio_execute_tool_response.py +24 -0
  178. vellum/client/types/composio_integration_exec_config.py +21 -0
  179. vellum/client/types/composio_tool_definition.py +30 -0
  180. vellum/client/types/conditional_node_result.py +3 -3
  181. vellum/client/types/conditional_node_result_data.py +2 -2
  182. vellum/client/types/container_image_build_config.py +21 -0
  183. vellum/client/types/container_image_container_image_tag.py +2 -2
  184. vellum/client/types/container_image_read.py +8 -4
  185. vellum/client/types/create_test_suite_test_case_request.py +6 -5
  186. vellum/client/types/create_workflow_event_request.py +7 -0
  187. vellum/client/types/dataset_row_push_request.py +20 -0
  188. vellum/client/types/delimiter_chunker_config.py +20 -0
  189. vellum/client/types/delimiter_chunker_config_request.py +20 -0
  190. vellum/client/types/delimiter_chunking.py +21 -0
  191. vellum/client/types/delimiter_chunking_request.py +21 -0
  192. vellum/client/types/deployment_history_item.py +7 -6
  193. vellum/client/types/deployment_provider_payload_response.py +4 -4
  194. vellum/client/types/deployment_read.py +14 -13
  195. vellum/client/types/deployment_release_tag_deployment_history_item.py +2 -2
  196. vellum/client/types/deployment_release_tag_read.py +4 -4
  197. vellum/client/types/deprecated_prompt_request_input.py +8 -0
  198. vellum/client/types/docker_service_token.py +2 -2
  199. vellum/client/types/document_chat_message_content.py +3 -3
  200. vellum/client/types/document_chat_message_content_request.py +3 -3
  201. vellum/client/types/document_document_to_document_index.py +9 -4
  202. vellum/client/types/document_index_chunking.py +5 -1
  203. vellum/client/types/document_index_chunking_request.py +3 -1
  204. vellum/client/types/document_index_indexing_config.py +4 -4
  205. vellum/client/types/document_index_indexing_config_request.py +4 -4
  206. vellum/client/types/document_index_read.py +4 -4
  207. vellum/client/types/document_input.py +30 -0
  208. vellum/client/types/document_input_request.py +30 -0
  209. vellum/client/types/document_prompt_block.py +4 -4
  210. vellum/client/types/document_read.py +9 -5
  211. vellum/client/types/document_vellum_value.py +3 -3
  212. vellum/client/types/document_vellum_value_request.py +3 -3
  213. vellum/client/types/enriched_normalized_completion.py +3 -3
  214. vellum/client/types/environment_display_config.py +19 -0
  215. vellum/client/types/environment_read.py +23 -0
  216. vellum/client/types/ephemeral_prompt_cache_config.py +3 -3
  217. vellum/client/types/error_detail_response.py +22 -0
  218. vellum/client/types/error_input.py +3 -3
  219. vellum/client/types/error_vellum_value.py +3 -3
  220. vellum/client/types/error_vellum_value_request.py +3 -3
  221. vellum/client/types/event_create_response.py +31 -0
  222. vellum/client/types/execute_api_request_bearer_token.py +1 -0
  223. vellum/client/types/execute_api_request_body.py +3 -1
  224. vellum/client/types/execute_api_request_headers_value.py +1 -0
  225. vellum/client/types/execute_api_response.py +6 -7
  226. vellum/client/types/execute_api_response_json.py +7 -0
  227. vellum/client/types/execute_prompt_event.py +3 -2
  228. vellum/client/types/execute_prompt_response.py +1 -0
  229. vellum/client/types/execute_workflow_async_response.py +26 -0
  230. vellum/client/types/execute_workflow_response.py +7 -6
  231. vellum/client/types/execute_workflow_workflow_result_event.py +1 -0
  232. vellum/client/types/execution_array_vellum_value.py +9 -8
  233. vellum/client/types/execution_audio_vellum_value.py +31 -0
  234. vellum/client/types/execution_chat_history_vellum_value.py +3 -3
  235. vellum/client/types/execution_document_vellum_value.py +31 -0
  236. vellum/client/types/execution_error_vellum_value.py +3 -3
  237. vellum/client/types/execution_function_call_vellum_value.py +3 -3
  238. vellum/client/types/execution_image_vellum_value.py +31 -0
  239. vellum/client/types/execution_json_vellum_value.py +3 -3
  240. vellum/client/types/execution_number_vellum_value.py +3 -3
  241. vellum/client/types/execution_search_results_vellum_value.py +3 -3
  242. vellum/client/types/execution_string_vellum_value.py +3 -3
  243. vellum/client/types/execution_thinking_vellum_value.py +31 -0
  244. vellum/client/types/execution_vellum_value.py +16 -5
  245. vellum/client/types/execution_video_vellum_value.py +31 -0
  246. vellum/client/types/external_input_descriptor.py +3 -3
  247. vellum/client/types/external_parent_context.py +38 -0
  248. vellum/client/types/external_test_case_execution.py +7 -6
  249. vellum/client/types/external_test_case_execution_request.py +7 -6
  250. vellum/client/types/fast_embed_vectorizer_baai_bge_small_en_v_15.py +23 -0
  251. vellum/client/types/fast_embed_vectorizer_baai_bge_small_en_v_15_request.py +23 -0
  252. vellum/client/types/folder_entity.py +5 -2
  253. vellum/client/types/folder_entity_dataset.py +26 -0
  254. vellum/client/types/folder_entity_dataset_data.py +25 -0
  255. vellum/client/types/folder_entity_document_index.py +3 -3
  256. vellum/client/types/folder_entity_document_index_data.py +5 -3
  257. vellum/client/types/folder_entity_folder.py +3 -3
  258. vellum/client/types/folder_entity_folder_data.py +2 -2
  259. vellum/client/types/folder_entity_prompt_sandbox.py +3 -3
  260. vellum/client/types/folder_entity_prompt_sandbox_data.py +4 -3
  261. vellum/client/types/folder_entity_test_suite.py +3 -3
  262. vellum/client/types/folder_entity_test_suite_data.py +3 -3
  263. vellum/client/types/folder_entity_workflow_sandbox.py +3 -3
  264. vellum/client/types/folder_entity_workflow_sandbox_data.py +6 -3
  265. vellum/client/types/fulfilled_ad_hoc_execute_prompt_event.py +4 -4
  266. vellum/client/types/fulfilled_execute_prompt_event.py +4 -4
  267. vellum/client/types/fulfilled_execute_prompt_response.py +3 -3
  268. vellum/client/types/fulfilled_execute_workflow_workflow_result_event.py +8 -9
  269. vellum/client/types/fulfilled_prompt_execution_meta.py +3 -3
  270. vellum/client/types/fulfilled_workflow_node_result_event.py +9 -8
  271. vellum/client/types/function_call.py +2 -2
  272. vellum/client/types/function_call_chat_message_content.py +3 -3
  273. vellum/client/types/function_call_chat_message_content_request.py +3 -3
  274. vellum/client/types/function_call_chat_message_content_value.py +2 -2
  275. vellum/client/types/function_call_chat_message_content_value_request.py +2 -2
  276. vellum/client/types/function_call_input.py +3 -3
  277. vellum/client/types/function_call_prompt_block.py +4 -4
  278. vellum/client/types/function_call_request.py +2 -2
  279. vellum/client/types/function_call_vellum_value.py +3 -3
  280. vellum/client/types/function_call_vellum_value_request.py +3 -3
  281. vellum/client/types/function_definition.py +9 -4
  282. vellum/client/types/generate_options_request.py +3 -3
  283. vellum/client/types/generate_request.py +2 -2
  284. vellum/client/types/generate_response.py +3 -3
  285. vellum/client/types/generate_result.py +3 -3
  286. vellum/client/types/generate_result_data.py +3 -3
  287. vellum/client/types/generate_result_error.py +3 -3
  288. vellum/client/types/generate_stream_response.py +3 -3
  289. vellum/client/types/generate_stream_result.py +4 -4
  290. vellum/client/types/generate_stream_result_data.py +3 -3
  291. vellum/client/types/google_vertex_ai_vectorizer_config.py +2 -2
  292. vellum/client/types/google_vertex_ai_vectorizer_config_request.py +2 -2
  293. vellum/client/types/google_vertex_ai_vectorizer_gemini_embedding_001.py +21 -0
  294. vellum/client/types/google_vertex_ai_vectorizer_gemini_embedding_001_request.py +21 -0
  295. vellum/client/types/google_vertex_ai_vectorizer_text_embedding_004.py +3 -3
  296. vellum/client/types/google_vertex_ai_vectorizer_text_embedding_004_request.py +3 -3
  297. vellum/client/types/google_vertex_ai_vectorizer_text_multilingual_embedding_002.py +3 -3
  298. vellum/client/types/google_vertex_ai_vectorizer_text_multilingual_embedding_002_request.py +3 -3
  299. vellum/client/types/hkunlp_instructor_xl_vectorizer.py +3 -3
  300. vellum/client/types/hkunlp_instructor_xl_vectorizer_request.py +3 -3
  301. vellum/client/types/image_chat_message_content.py +3 -3
  302. vellum/client/types/image_chat_message_content_request.py +3 -3
  303. vellum/client/types/image_input.py +30 -0
  304. vellum/client/types/image_input_request.py +30 -0
  305. vellum/client/types/image_prompt_block.py +4 -4
  306. vellum/client/types/image_vellum_value.py +3 -3
  307. vellum/client/types/image_vellum_value_request.py +3 -3
  308. vellum/client/types/indexing_config_vectorizer.py +11 -4
  309. vellum/client/types/indexing_config_vectorizer_request.py +11 -4
  310. vellum/client/types/initiated_ad_hoc_execute_prompt_event.py +3 -3
  311. vellum/client/types/initiated_execute_prompt_event.py +3 -3
  312. vellum/client/types/initiated_prompt_execution_meta.py +2 -2
  313. vellum/client/types/initiated_workflow_node_result_event.py +9 -8
  314. vellum/client/types/instructor_vectorizer_config.py +2 -2
  315. vellum/client/types/instructor_vectorizer_config_request.py +2 -2
  316. vellum/client/types/integration.py +27 -0
  317. vellum/client/types/integration_auth_config_integration.py +23 -0
  318. vellum/client/types/integration_auth_config_integration_credential.py +19 -0
  319. vellum/client/types/integration_credential_access_type.py +5 -0
  320. vellum/client/types/integration_name.py +85 -0
  321. vellum/client/types/integration_provider.py +5 -0
  322. vellum/client/types/integration_read.py +30 -0
  323. vellum/client/types/integration_trigger_context.py +39 -0
  324. vellum/client/types/invoked_port.py +2 -2
  325. vellum/client/types/jinja_prompt_block.py +4 -4
  326. vellum/client/types/json_input.py +3 -3
  327. vellum/client/types/json_input_request.py +3 -3
  328. vellum/client/types/json_vellum_value.py +2 -2
  329. vellum/client/types/json_vellum_value_request.py +2 -2
  330. vellum/client/types/logical_operator.py +4 -0
  331. vellum/client/types/map_node_result.py +3 -3
  332. vellum/client/types/map_node_result_data.py +3 -3
  333. vellum/client/types/merge_node_result.py +3 -3
  334. vellum/client/types/merge_node_result_data.py +2 -2
  335. vellum/client/types/metadata_filter_config_request.py +9 -8
  336. vellum/client/types/metadata_filter_rule_request.py +5 -5
  337. vellum/client/types/metadata_filters_request.py +1 -0
  338. vellum/client/types/metric_definition_execution.py +7 -6
  339. vellum/client/types/metric_definition_history_item.py +7 -6
  340. vellum/client/types/metric_definition_input.py +3 -2
  341. vellum/client/types/metric_node_result.py +2 -2
  342. vellum/client/types/ml_model_read.py +6 -3
  343. vellum/client/types/ml_model_usage.py +2 -2
  344. vellum/client/types/ml_model_usage_wrapper.py +4 -4
  345. vellum/client/types/named_scenario_input_audio_variable_value_request.py +22 -0
  346. vellum/client/types/named_scenario_input_chat_history_variable_value_request.py +3 -3
  347. vellum/client/types/named_scenario_input_document_variable_value_request.py +22 -0
  348. vellum/client/types/named_scenario_input_image_variable_value_request.py +22 -0
  349. vellum/client/types/named_scenario_input_json_variable_value_request.py +2 -2
  350. vellum/client/types/named_scenario_input_request.py +11 -2
  351. vellum/client/types/named_scenario_input_string_variable_value_request.py +2 -2
  352. vellum/client/types/named_scenario_input_video_variable_value_request.py +22 -0
  353. vellum/client/types/named_test_case_array_variable_value.py +8 -7
  354. vellum/client/types/named_test_case_array_variable_value_request.py +8 -9
  355. vellum/client/types/named_test_case_audio_variable_value.py +26 -0
  356. vellum/client/types/named_test_case_audio_variable_value_request.py +26 -0
  357. vellum/client/types/named_test_case_chat_history_variable_value.py +3 -3
  358. vellum/client/types/named_test_case_chat_history_variable_value_request.py +3 -3
  359. vellum/client/types/named_test_case_document_variable_value.py +22 -0
  360. vellum/client/types/named_test_case_document_variable_value_request.py +22 -0
  361. vellum/client/types/named_test_case_error_variable_value.py +3 -3
  362. vellum/client/types/named_test_case_error_variable_value_request.py +3 -3
  363. vellum/client/types/named_test_case_function_call_variable_value.py +3 -3
  364. vellum/client/types/named_test_case_function_call_variable_value_request.py +3 -3
  365. vellum/client/types/named_test_case_image_variable_value.py +22 -0
  366. vellum/client/types/named_test_case_image_variable_value_request.py +22 -0
  367. vellum/client/types/named_test_case_json_variable_value.py +2 -2
  368. vellum/client/types/named_test_case_json_variable_value_request.py +2 -2
  369. vellum/client/types/named_test_case_number_variable_value.py +2 -2
  370. vellum/client/types/named_test_case_number_variable_value_request.py +2 -2
  371. vellum/client/types/named_test_case_search_results_variable_value.py +3 -3
  372. vellum/client/types/named_test_case_search_results_variable_value_request.py +3 -3
  373. vellum/client/types/named_test_case_string_variable_value.py +2 -2
  374. vellum/client/types/named_test_case_string_variable_value_request.py +2 -2
  375. vellum/client/types/named_test_case_variable_value.py +14 -5
  376. vellum/client/types/named_test_case_variable_value_request.py +14 -5
  377. vellum/client/types/named_test_case_video_variable_value.py +22 -0
  378. vellum/client/types/named_test_case_video_variable_value_request.py +22 -0
  379. vellum/client/types/node_execution_fulfilled_body.py +4 -4
  380. vellum/client/types/node_execution_fulfilled_event.py +21 -23
  381. vellum/client/types/node_execution_initiated_body.py +3 -3
  382. vellum/client/types/node_execution_initiated_event.py +21 -23
  383. vellum/client/types/node_execution_paused_body.py +3 -3
  384. vellum/client/types/node_execution_paused_event.py +21 -23
  385. vellum/client/types/node_execution_rejected_body.py +5 -4
  386. vellum/client/types/node_execution_rejected_event.py +21 -23
  387. vellum/client/types/node_execution_resumed_body.py +3 -3
  388. vellum/client/types/node_execution_resumed_event.py +21 -23
  389. vellum/client/types/node_execution_span.py +20 -20
  390. vellum/client/types/node_execution_span_attributes.py +4 -2
  391. vellum/client/types/node_execution_streaming_body.py +4 -4
  392. vellum/client/types/node_execution_streaming_event.py +21 -23
  393. vellum/client/types/node_input_compiled_array_value.py +8 -7
  394. vellum/client/types/node_input_compiled_audio_value.py +23 -0
  395. vellum/client/types/node_input_compiled_chat_history_value.py +3 -3
  396. vellum/client/types/node_input_compiled_document_value.py +23 -0
  397. vellum/client/types/node_input_compiled_error_value.py +3 -3
  398. vellum/client/types/node_input_compiled_function_call_value.py +3 -3
  399. vellum/client/types/node_input_compiled_image_value.py +23 -0
  400. vellum/client/types/node_input_compiled_json_value.py +2 -2
  401. vellum/client/types/node_input_compiled_number_value.py +2 -2
  402. vellum/client/types/node_input_compiled_search_results_value.py +3 -3
  403. vellum/client/types/node_input_compiled_secret_value.py +3 -3
  404. vellum/client/types/node_input_compiled_string_value.py +2 -2
  405. vellum/client/types/node_input_compiled_video_value.py +23 -0
  406. vellum/client/types/node_input_variable_compiled_value.py +14 -5
  407. vellum/client/types/node_output_compiled_array_value.py +9 -8
  408. vellum/client/types/node_output_compiled_chat_history_value.py +3 -3
  409. vellum/client/types/node_output_compiled_error_value.py +3 -3
  410. vellum/client/types/node_output_compiled_function_call_value.py +3 -3
  411. vellum/client/types/node_output_compiled_json_value.py +3 -3
  412. vellum/client/types/node_output_compiled_number_value.py +3 -3
  413. vellum/client/types/node_output_compiled_search_results_value.py +3 -3
  414. vellum/client/types/node_output_compiled_string_value.py +3 -3
  415. vellum/client/types/node_output_compiled_thinking_value.py +28 -0
  416. vellum/client/types/node_output_compiled_value.py +8 -5
  417. vellum/client/types/node_parent_context.py +15 -18
  418. vellum/client/types/normalized_log_probs.py +3 -3
  419. vellum/client/types/normalized_token_log_probs.py +2 -2
  420. vellum/client/types/number_input.py +3 -3
  421. vellum/client/types/number_vellum_value.py +2 -2
  422. vellum/client/types/number_vellum_value_request.py +2 -2
  423. vellum/client/types/open_ai_vectorizer_config.py +3 -3
  424. vellum/client/types/open_ai_vectorizer_config_request.py +3 -3
  425. vellum/client/types/open_ai_vectorizer_text_embedding_3_large.py +3 -3
  426. vellum/client/types/open_ai_vectorizer_text_embedding_3_large_request.py +3 -3
  427. vellum/client/types/open_ai_vectorizer_text_embedding_3_small.py +3 -3
  428. vellum/client/types/open_ai_vectorizer_text_embedding_3_small_request.py +3 -3
  429. vellum/client/types/open_ai_vectorizer_text_embedding_ada_002.py +3 -3
  430. vellum/client/types/open_ai_vectorizer_text_embedding_ada_002_request.py +3 -3
  431. vellum/client/types/organization_read.py +6 -3
  432. vellum/client/types/paginated_container_image_read_list.py +3 -3
  433. vellum/client/types/paginated_deployment_release_tag_read_list.py +3 -3
  434. vellum/client/types/paginated_document_index_read_list.py +3 -3
  435. vellum/client/types/paginated_folder_entity_list.py +3 -3
  436. vellum/client/types/paginated_slim_deployment_read_list.py +7 -6
  437. vellum/client/types/paginated_slim_document_list.py +3 -3
  438. vellum/client/types/paginated_slim_integration_auth_config_read_list.py +23 -0
  439. vellum/client/types/paginated_slim_integration_read_list.py +23 -0
  440. vellum/client/types/paginated_slim_tool_definition_list.py +23 -0
  441. vellum/client/types/paginated_slim_workflow_deployment_list.py +7 -6
  442. vellum/client/types/paginated_test_suite_run_execution_list.py +7 -6
  443. vellum/client/types/paginated_test_suite_test_case_list.py +7 -6
  444. vellum/client/types/paginated_workflow_deployment_release_list.py +30 -0
  445. vellum/client/types/paginated_workflow_release_tag_read_list.py +3 -3
  446. vellum/client/types/paginated_workflow_sandbox_example_list.py +3 -3
  447. vellum/client/types/parent_context.py +21 -11
  448. vellum/client/types/pdf_search_result_meta_source.py +2 -2
  449. vellum/client/types/pdf_search_result_meta_source_request.py +2 -2
  450. vellum/client/types/plain_text_prompt_block.py +4 -4
  451. vellum/client/types/price.py +3 -3
  452. vellum/client/types/private_vectorizer.py +23 -0
  453. vellum/client/types/private_vectorizer_request.py +23 -0
  454. vellum/client/types/processing_failure_reason_enum.py +3 -1
  455. vellum/client/types/prompt_block.py +9 -6
  456. vellum/client/types/prompt_deployment_expand_meta_request.py +2 -2
  457. vellum/client/types/prompt_deployment_input_request.py +16 -3
  458. vellum/client/types/prompt_deployment_parent_context.py +14 -17
  459. vellum/client/types/prompt_deployment_release.py +6 -6
  460. vellum/client/types/prompt_deployment_release_prompt_deployment.py +2 -2
  461. vellum/client/types/prompt_deployment_release_prompt_version.py +7 -2
  462. vellum/client/types/prompt_exec_config.py +12 -12
  463. vellum/client/types/prompt_execution_meta.py +3 -3
  464. vellum/client/types/prompt_node_execution_meta.py +3 -3
  465. vellum/client/types/prompt_node_result.py +3 -3
  466. vellum/client/types/prompt_node_result_data.py +3 -3
  467. vellum/client/types/prompt_output.py +7 -3
  468. vellum/client/types/prompt_parameters.py +2 -2
  469. vellum/client/types/prompt_push_response.py +20 -0
  470. vellum/client/types/prompt_request_audio_input.py +26 -0
  471. vellum/client/types/prompt_request_chat_history_input.py +3 -3
  472. vellum/client/types/prompt_request_document_input.py +26 -0
  473. vellum/client/types/prompt_request_image_input.py +26 -0
  474. vellum/client/types/prompt_request_input.py +16 -3
  475. vellum/client/types/prompt_request_json_input.py +3 -3
  476. vellum/client/types/prompt_request_string_input.py +3 -3
  477. vellum/client/types/prompt_request_video_input.py +26 -0
  478. vellum/client/types/prompt_settings.py +3 -2
  479. vellum/client/types/prompt_version_build_config_sandbox.py +22 -0
  480. vellum/client/types/raw_prompt_execution_overrides_request.py +2 -2
  481. vellum/client/types/reducto_chunker_config.py +2 -2
  482. vellum/client/types/reducto_chunker_config_request.py +2 -2
  483. vellum/client/types/reducto_chunking.py +3 -3
  484. vellum/client/types/reducto_chunking_request.py +3 -3
  485. vellum/client/types/rejected_ad_hoc_execute_prompt_event.py +4 -4
  486. vellum/client/types/rejected_execute_prompt_event.py +4 -4
  487. vellum/client/types/rejected_execute_prompt_response.py +3 -3
  488. vellum/client/types/rejected_execute_workflow_workflow_result_event.py +4 -4
  489. vellum/client/types/rejected_prompt_execution_meta.py +3 -3
  490. vellum/client/types/rejected_workflow_node_result_event.py +9 -8
  491. vellum/client/types/release_created_by.py +2 -2
  492. vellum/client/types/release_environment.py +2 -2
  493. vellum/client/types/release_release_tag.py +3 -3
  494. vellum/client/types/release_review_reviewer.py +2 -2
  495. vellum/client/types/release_tag_release.py +2 -2
  496. vellum/client/types/replace_test_suite_test_case_request.py +6 -5
  497. vellum/client/types/rich_text_child_block.py +2 -1
  498. vellum/client/types/rich_text_prompt_block.py +4 -4
  499. vellum/client/types/sandbox_scenario.py +3 -3
  500. vellum/client/types/scenario_input.py +14 -3
  501. vellum/client/types/scenario_input_audio_variable_value.py +22 -0
  502. vellum/client/types/scenario_input_chat_history_variable_value.py +3 -3
  503. vellum/client/types/scenario_input_document_variable_value.py +22 -0
  504. vellum/client/types/scenario_input_image_variable_value.py +22 -0
  505. vellum/client/types/scenario_input_json_variable_value.py +2 -2
  506. vellum/client/types/scenario_input_string_variable_value.py +2 -2
  507. vellum/client/types/scenario_input_video_variable_value.py +22 -0
  508. vellum/client/types/scheduled_trigger_context.py +39 -0
  509. vellum/client/types/search_filters_request.py +8 -9
  510. vellum/client/types/search_node_result.py +3 -3
  511. vellum/client/types/search_node_result_data.py +3 -3
  512. vellum/client/types/search_request_options_request.py +10 -11
  513. vellum/client/types/search_response.py +3 -3
  514. vellum/client/types/search_result.py +3 -3
  515. vellum/client/types/search_result_document.py +2 -2
  516. vellum/client/types/search_result_document_request.py +2 -2
  517. vellum/client/types/search_result_merging_request.py +2 -2
  518. vellum/client/types/search_result_meta.py +3 -3
  519. vellum/client/types/search_result_meta_request.py +3 -3
  520. vellum/client/types/search_result_request.py +3 -3
  521. vellum/client/types/search_results_input.py +3 -3
  522. vellum/client/types/search_results_vellum_value.py +3 -3
  523. vellum/client/types/search_results_vellum_value_request.py +3 -3
  524. vellum/client/types/search_weights_request.py +2 -2
  525. vellum/client/types/secret_type_enum.py +3 -1
  526. vellum/client/types/sentence_chunker_config.py +2 -2
  527. vellum/client/types/sentence_chunker_config_request.py +2 -2
  528. vellum/client/types/sentence_chunking.py +3 -3
  529. vellum/client/types/sentence_chunking_request.py +3 -3
  530. vellum/client/types/slim_composio_tool_definition.py +24 -0
  531. vellum/client/types/slim_deployment_read.py +12 -11
  532. vellum/client/types/slim_document.py +6 -5
  533. vellum/client/types/slim_document_document_to_document_index.py +9 -4
  534. vellum/client/types/slim_integration_auth_config_read.py +36 -0
  535. vellum/client/types/slim_integration_read.py +25 -0
  536. vellum/client/types/slim_release_review.py +4 -4
  537. vellum/client/types/slim_workflow_deployment.py +13 -12
  538. vellum/client/types/slim_workflow_execution_read.py +21 -24
  539. vellum/client/types/span_link.py +16 -19
  540. vellum/client/types/span_link_type_enum.py +1 -1
  541. vellum/client/types/streaming_ad_hoc_execute_prompt_event.py +4 -4
  542. vellum/client/types/streaming_execute_prompt_event.py +3 -3
  543. vellum/client/types/streaming_prompt_execution_meta.py +2 -2
  544. vellum/client/types/streaming_workflow_node_result_event.py +9 -8
  545. vellum/client/types/string_chat_message_content.py +2 -2
  546. vellum/client/types/string_chat_message_content_request.py +2 -2
  547. vellum/client/types/string_input.py +3 -3
  548. vellum/client/types/string_input_request.py +3 -3
  549. vellum/client/types/string_vellum_value.py +2 -2
  550. vellum/client/types/string_vellum_value_request.py +2 -2
  551. vellum/client/types/submit_completion_actual_request.py +3 -3
  552. vellum/client/types/submit_workflow_execution_actual_request.py +3 -2
  553. vellum/client/types/subworkflow_node_result.py +3 -3
  554. vellum/client/types/subworkflow_node_result_data.py +2 -2
  555. vellum/client/types/templating_node_array_result.py +8 -7
  556. vellum/client/types/templating_node_chat_history_result.py +3 -3
  557. vellum/client/types/templating_node_error_result.py +3 -3
  558. vellum/client/types/templating_node_function_call_result.py +3 -3
  559. vellum/client/types/templating_node_json_result.py +2 -2
  560. vellum/client/types/templating_node_number_result.py +2 -2
  561. vellum/client/types/templating_node_result.py +7 -6
  562. vellum/client/types/templating_node_result_data.py +7 -6
  563. vellum/client/types/templating_node_result_output.py +6 -5
  564. vellum/client/types/templating_node_search_results_result.py +3 -3
  565. vellum/client/types/templating_node_string_result.py +2 -2
  566. vellum/client/types/terminal_node_array_result.py +8 -7
  567. vellum/client/types/terminal_node_chat_history_result.py +2 -2
  568. vellum/client/types/terminal_node_error_result.py +2 -2
  569. vellum/client/types/terminal_node_function_call_result.py +2 -2
  570. vellum/client/types/terminal_node_json_result.py +2 -2
  571. vellum/client/types/terminal_node_number_result.py +2 -2
  572. vellum/client/types/terminal_node_result.py +7 -6
  573. vellum/client/types/terminal_node_result_data.py +7 -6
  574. vellum/client/types/terminal_node_result_output.py +6 -5
  575. vellum/client/types/terminal_node_search_results_result.py +2 -2
  576. vellum/client/types/terminal_node_string_result.py +2 -2
  577. vellum/client/types/test_case_array_variable_value.py +8 -7
  578. vellum/client/types/test_case_audio_variable_value.py +27 -0
  579. vellum/client/types/test_case_chat_history_variable_value.py +3 -3
  580. vellum/client/types/test_case_document_variable_value.py +27 -0
  581. vellum/client/types/test_case_error_variable_value.py +3 -3
  582. vellum/client/types/test_case_function_call_variable_value.py +3 -3
  583. vellum/client/types/test_case_image_variable_value.py +27 -0
  584. vellum/client/types/test_case_json_variable_value.py +2 -2
  585. vellum/client/types/test_case_number_variable_value.py +2 -2
  586. vellum/client/types/test_case_search_results_variable_value.py +3 -3
  587. vellum/client/types/test_case_string_variable_value.py +2 -2
  588. vellum/client/types/test_case_variable_value.py +14 -5
  589. vellum/client/types/test_case_video_variable_value.py +27 -0
  590. vellum/client/types/test_suite_run_deployment_release_tag_exec_config.py +3 -3
  591. vellum/client/types/test_suite_run_deployment_release_tag_exec_config_data.py +3 -3
  592. vellum/client/types/test_suite_run_deployment_release_tag_exec_config_data_request.py +3 -3
  593. vellum/client/types/test_suite_run_deployment_release_tag_exec_config_request.py +3 -3
  594. vellum/client/types/test_suite_run_exec_config.py +2 -1
  595. vellum/client/types/test_suite_run_exec_config_request.py +2 -1
  596. vellum/client/types/test_suite_run_execution.py +8 -7
  597. vellum/client/types/test_suite_run_execution_array_output.py +8 -7
  598. vellum/client/types/test_suite_run_execution_chat_history_output.py +3 -3
  599. vellum/client/types/test_suite_run_execution_error_output.py +3 -3
  600. vellum/client/types/test_suite_run_execution_function_call_output.py +3 -3
  601. vellum/client/types/test_suite_run_execution_json_output.py +2 -2
  602. vellum/client/types/test_suite_run_execution_metric_definition.py +2 -2
  603. vellum/client/types/test_suite_run_execution_metric_result.py +8 -7
  604. vellum/client/types/test_suite_run_execution_number_output.py +2 -2
  605. vellum/client/types/test_suite_run_execution_output.py +6 -5
  606. vellum/client/types/test_suite_run_execution_search_results_output.py +3 -3
  607. vellum/client/types/test_suite_run_execution_string_output.py +2 -2
  608. vellum/client/types/test_suite_run_external_exec_config.py +7 -6
  609. vellum/client/types/test_suite_run_external_exec_config_data.py +7 -6
  610. vellum/client/types/test_suite_run_external_exec_config_data_request.py +7 -8
  611. vellum/client/types/test_suite_run_external_exec_config_request.py +7 -8
  612. vellum/client/types/test_suite_run_metric_array_output.py +8 -7
  613. vellum/client/types/test_suite_run_metric_error_output.py +3 -3
  614. vellum/client/types/test_suite_run_metric_json_output.py +2 -2
  615. vellum/client/types/test_suite_run_metric_number_output.py +2 -2
  616. vellum/client/types/test_suite_run_metric_output.py +5 -4
  617. vellum/client/types/test_suite_run_metric_string_output.py +2 -2
  618. vellum/client/types/test_suite_run_progress.py +2 -2
  619. vellum/client/types/test_suite_run_prompt_sandbox_exec_config_data_request.py +3 -3
  620. vellum/client/types/test_suite_run_prompt_sandbox_exec_config_request.py +3 -3
  621. vellum/client/types/test_suite_run_prompt_sandbox_history_item_exec_config.py +3 -3
  622. vellum/client/types/test_suite_run_prompt_sandbox_history_item_exec_config_data.py +3 -3
  623. vellum/client/types/test_suite_run_prompt_sandbox_history_item_exec_config_data_request.py +3 -3
  624. vellum/client/types/test_suite_run_prompt_sandbox_history_item_exec_config_request.py +3 -3
  625. vellum/client/types/test_suite_run_read.py +9 -8
  626. vellum/client/types/test_suite_run_test_suite.py +2 -2
  627. vellum/client/types/test_suite_run_workflow_release_tag_exec_config.py +3 -3
  628. vellum/client/types/test_suite_run_workflow_release_tag_exec_config_data.py +3 -3
  629. vellum/client/types/test_suite_run_workflow_release_tag_exec_config_data_request.py +3 -3
  630. vellum/client/types/test_suite_run_workflow_release_tag_exec_config_request.py +3 -3
  631. vellum/client/types/test_suite_run_workflow_sandbox_exec_config_data_request.py +3 -3
  632. vellum/client/types/test_suite_run_workflow_sandbox_exec_config_request.py +3 -3
  633. vellum/client/types/test_suite_run_workflow_sandbox_history_item_exec_config.py +3 -3
  634. vellum/client/types/test_suite_run_workflow_sandbox_history_item_exec_config_data.py +3 -3
  635. vellum/client/types/test_suite_run_workflow_sandbox_history_item_exec_config_data_request.py +3 -3
  636. vellum/client/types/test_suite_run_workflow_sandbox_history_item_exec_config_request.py +3 -3
  637. vellum/client/types/test_suite_test_case.py +7 -6
  638. vellum/client/types/test_suite_test_case_bulk_operation_request.py +2 -1
  639. vellum/client/types/test_suite_test_case_bulk_result.py +2 -1
  640. vellum/client/types/test_suite_test_case_create_bulk_operation_request.py +7 -8
  641. vellum/client/types/test_suite_test_case_created_bulk_result.py +3 -3
  642. vellum/client/types/test_suite_test_case_created_bulk_result_data.py +2 -2
  643. vellum/client/types/test_suite_test_case_delete_bulk_operation_data_request.py +2 -2
  644. vellum/client/types/test_suite_test_case_delete_bulk_operation_request.py +3 -3
  645. vellum/client/types/test_suite_test_case_deleted_bulk_result.py +3 -3
  646. vellum/client/types/test_suite_test_case_deleted_bulk_result_data.py +2 -2
  647. vellum/client/types/test_suite_test_case_rejected_bulk_result.py +2 -2
  648. vellum/client/types/test_suite_test_case_replace_bulk_operation_request.py +7 -8
  649. vellum/client/types/test_suite_test_case_replaced_bulk_result.py +3 -3
  650. vellum/client/types/test_suite_test_case_replaced_bulk_result_data.py +2 -2
  651. vellum/client/types/test_suite_test_case_upsert_bulk_operation_request.py +7 -8
  652. vellum/client/types/thinking_vellum_value.py +25 -0
  653. vellum/client/types/thinking_vellum_value_request.py +25 -0
  654. vellum/client/types/token_overlapping_window_chunker_config.py +2 -2
  655. vellum/client/types/token_overlapping_window_chunker_config_request.py +2 -2
  656. vellum/client/types/token_overlapping_window_chunking.py +3 -3
  657. vellum/client/types/token_overlapping_window_chunking_request.py +3 -3
  658. vellum/client/types/update_active_workspace_response.py +32 -0
  659. vellum/client/types/upload_document_response.py +3 -3
  660. vellum/client/types/uploaded_file_read.py +27 -0
  661. vellum/client/types/upsert_test_suite_test_case_request.py +6 -5
  662. vellum/client/types/variable_prompt_block.py +11 -4
  663. vellum/client/types/vellum_audio.py +5 -4
  664. vellum/client/types/vellum_audio_request.py +3 -3
  665. vellum/client/types/vellum_code_resource_definition.py +7 -2
  666. vellum/client/types/vellum_document.py +9 -4
  667. vellum/client/types/vellum_document_request.py +7 -3
  668. vellum/client/types/vellum_error.py +5 -4
  669. vellum/client/types/vellum_error_code_enum.py +6 -0
  670. vellum/client/types/vellum_error_request.py +5 -4
  671. vellum/client/types/vellum_image.py +9 -4
  672. vellum/client/types/vellum_image_request.py +7 -3
  673. vellum/client/types/vellum_node_execution_event.py +4 -3
  674. vellum/client/types/vellum_sdk_error.py +4 -3
  675. vellum/client/types/vellum_sdk_error_code_enum.py +5 -0
  676. vellum/client/types/vellum_secret.py +2 -2
  677. vellum/client/types/vellum_span.py +2 -1
  678. vellum/client/types/vellum_value.py +13 -8
  679. vellum/client/types/vellum_value_logical_condition_group_request.py +6 -9
  680. vellum/client/types/vellum_value_logical_condition_request.py +10 -9
  681. vellum/client/types/vellum_value_logical_expression_request.py +2 -1
  682. vellum/client/types/vellum_value_request.py +13 -8
  683. vellum/client/types/vellum_variable.py +10 -9
  684. vellum/client/types/vellum_variable_extensions.py +3 -2
  685. vellum/client/types/vellum_variable_type.py +3 -1
  686. vellum/client/types/vellum_video.py +25 -0
  687. vellum/client/types/vellum_video_request.py +24 -0
  688. vellum/client/types/vellum_workflow_execution_event.py +4 -3
  689. vellum/client/types/video_chat_message_content.py +25 -0
  690. vellum/client/types/video_chat_message_content_request.py +25 -0
  691. vellum/client/types/video_input.py +30 -0
  692. vellum/client/types/video_input_request.py +30 -0
  693. vellum/client/types/video_prompt_block.py +29 -0
  694. vellum/client/types/video_vellum_value.py +25 -0
  695. vellum/client/types/video_vellum_value_request.py +25 -0
  696. vellum/client/types/workflow_deployment_display_data.py +27 -0
  697. vellum/client/types/workflow_deployment_event_executions_response.py +17 -34
  698. vellum/client/types/workflow_deployment_history_item.py +7 -6
  699. vellum/client/types/workflow_deployment_parent_context.py +14 -17
  700. vellum/client/types/workflow_deployment_read.py +19 -12
  701. vellum/client/types/workflow_deployment_release.py +10 -9
  702. vellum/client/types/workflow_deployment_release_workflow_deployment.py +2 -2
  703. vellum/client/types/workflow_deployment_release_workflow_version.py +7 -6
  704. vellum/client/types/workflow_display_icon.py +24 -0
  705. vellum/client/types/workflow_error.py +1 -0
  706. vellum/client/types/workflow_event.py +37 -0
  707. vellum/client/types/workflow_event_error.py +5 -3
  708. vellum/client/types/workflow_event_execution_read.py +23 -29
  709. vellum/client/types/workflow_execution_actual.py +8 -7
  710. vellum/client/types/workflow_execution_actual_chat_history_request.py +2 -2
  711. vellum/client/types/workflow_execution_actual_json_request.py +2 -2
  712. vellum/client/types/workflow_execution_actual_string_request.py +2 -2
  713. vellum/client/types/workflow_execution_detail.py +51 -0
  714. vellum/client/types/workflow_execution_event_error_code.py +5 -0
  715. vellum/client/types/workflow_execution_fulfilled_body.py +5 -3
  716. vellum/client/types/workflow_execution_fulfilled_event.py +21 -23
  717. vellum/client/types/workflow_execution_initiated_body.py +3 -12
  718. vellum/client/types/workflow_execution_initiated_event.py +21 -27
  719. vellum/client/types/workflow_execution_node_result_event.py +7 -6
  720. vellum/client/types/workflow_execution_paused_body.py +4 -4
  721. vellum/client/types/workflow_execution_paused_event.py +21 -23
  722. vellum/client/types/workflow_execution_rejected_body.py +5 -4
  723. vellum/client/types/workflow_execution_rejected_event.py +21 -23
  724. vellum/client/types/workflow_execution_resumed_body.py +3 -3
  725. vellum/client/types/workflow_execution_resumed_event.py +21 -23
  726. vellum/client/types/workflow_execution_snapshotted_body.py +4 -3
  727. vellum/client/types/workflow_execution_snapshotted_event.py +21 -25
  728. vellum/client/types/workflow_execution_span.py +19 -23
  729. vellum/client/types/workflow_execution_span_attributes.py +3 -2
  730. vellum/client/types/workflow_execution_streaming_body.py +4 -4
  731. vellum/client/types/workflow_execution_streaming_event.py +21 -23
  732. vellum/client/types/workflow_execution_usage_calculation_error.py +21 -0
  733. vellum/client/types/workflow_execution_usage_calculation_error_code_enum.py +7 -0
  734. vellum/client/types/workflow_execution_usage_calculation_fulfilled_body.py +3 -3
  735. vellum/client/types/workflow_execution_usage_result.py +24 -0
  736. vellum/client/types/workflow_execution_view_online_eval_metric_result.py +7 -8
  737. vellum/client/types/workflow_execution_workflow_result_event.py +7 -6
  738. vellum/client/types/workflow_expand_meta_request.py +2 -2
  739. vellum/client/types/workflow_initialization_error.py +2 -2
  740. vellum/client/types/workflow_input.py +31 -0
  741. vellum/client/types/workflow_node_result_data.py +8 -7
  742. vellum/client/types/workflow_node_result_event.py +3 -2
  743. vellum/client/types/workflow_output.py +12 -5
  744. vellum/client/types/workflow_output_array.py +9 -8
  745. vellum/client/types/workflow_output_audio.py +31 -0
  746. vellum/client/types/workflow_output_chat_history.py +3 -3
  747. vellum/client/types/workflow_output_document.py +31 -0
  748. vellum/client/types/workflow_output_error.py +3 -3
  749. vellum/client/types/workflow_output_function_call.py +3 -3
  750. vellum/client/types/workflow_output_image.py +3 -3
  751. vellum/client/types/workflow_output_json.py +3 -3
  752. vellum/client/types/workflow_output_number.py +3 -3
  753. vellum/client/types/workflow_output_search_results.py +3 -3
  754. vellum/client/types/workflow_output_string.py +3 -3
  755. vellum/client/types/workflow_output_video.py +31 -0
  756. vellum/client/types/workflow_parent_context.py +15 -18
  757. vellum/client/types/workflow_push_deployment_config_request.py +3 -2
  758. vellum/client/types/workflow_push_response.py +2 -2
  759. vellum/client/types/workflow_release_tag_read.py +4 -4
  760. vellum/client/types/workflow_release_tag_workflow_deployment_history_item.py +2 -2
  761. vellum/client/types/workflow_request_audio_input_request.py +30 -0
  762. vellum/client/types/workflow_request_chat_history_input_request.py +3 -3
  763. vellum/client/types/workflow_request_document_input_request.py +30 -0
  764. vellum/client/types/workflow_request_image_input_request.py +30 -0
  765. vellum/client/types/workflow_request_input_request.py +11 -2
  766. vellum/client/types/workflow_request_json_input_request.py +3 -3
  767. vellum/client/types/workflow_request_number_input_request.py +3 -3
  768. vellum/client/types/workflow_request_string_input_request.py +3 -3
  769. vellum/client/types/workflow_request_video_input_request.py +30 -0
  770. vellum/client/types/workflow_resolved_state.py +31 -0
  771. vellum/client/types/workflow_result_event.py +11 -10
  772. vellum/client/types/workflow_result_event_output_data.py +7 -6
  773. vellum/client/types/workflow_result_event_output_data_array.py +9 -8
  774. vellum/client/types/workflow_result_event_output_data_chat_history.py +3 -3
  775. vellum/client/types/workflow_result_event_output_data_error.py +3 -3
  776. vellum/client/types/workflow_result_event_output_data_function_call.py +3 -3
  777. vellum/client/types/workflow_result_event_output_data_json.py +3 -3
  778. vellum/client/types/workflow_result_event_output_data_number.py +3 -3
  779. vellum/client/types/workflow_result_event_output_data_search_results.py +3 -3
  780. vellum/client/types/workflow_result_event_output_data_string.py +3 -3
  781. vellum/client/types/workflow_result_event_state.py +7 -0
  782. vellum/client/types/workflow_sandbox_display_data.py +27 -0
  783. vellum/client/types/workflow_sandbox_example.py +4 -2
  784. vellum/client/types/workflow_sandbox_parent_context.py +14 -17
  785. vellum/client/types/workflow_stream_event.py +2 -1
  786. vellum/client/types/workspace_display_config.py +19 -0
  787. vellum/client/types/workspace_read.py +5 -3
  788. vellum/client/types/workspace_secret_read.py +3 -3
  789. vellum/client/utils.py +24 -0
  790. vellum/{types/node_event_display_context.py → core/force_multipart.py} +1 -1
  791. vellum/core/http_response.py +3 -0
  792. vellum/errors/misdirected_request_error.py +3 -0
  793. vellum/errors/too_many_requests_error.py +3 -0
  794. vellum/errors/unauthorized_error.py +3 -0
  795. vellum/evaluations/resources.py +5 -5
  796. vellum/plugins/pydantic.py +14 -3
  797. vellum/plugins/tests/__init__.py +0 -0
  798. vellum/plugins/tests/test_pydantic.py +30 -0
  799. vellum/plugins/vellum_mypy.py +31 -23
  800. vellum/prompts/__init__.py +3 -0
  801. vellum/prompts/blocks/__init__.py +3 -0
  802. vellum/prompts/blocks/compilation.py +29 -11
  803. vellum/prompts/blocks/helpers.py +31 -0
  804. vellum/prompts/blocks/tests/test_compilation.py +64 -0
  805. vellum/raw_client.py +3 -0
  806. vellum/resources/ad_hoc/raw_client.py +3 -0
  807. vellum/resources/container_images/raw_client.py +3 -0
  808. vellum/resources/deployments/raw_client.py +3 -0
  809. vellum/resources/document_indexes/raw_client.py +3 -0
  810. vellum/resources/documents/raw_client.py +3 -0
  811. vellum/resources/{release_reviews → environments}/__init__.py +1 -1
  812. vellum/resources/{release_reviews → environments}/client.py +1 -1
  813. vellum/resources/environments/raw_client.py +3 -0
  814. vellum/resources/events/__init__.py +3 -0
  815. vellum/resources/events/client.py +3 -0
  816. vellum/resources/events/raw_client.py +3 -0
  817. vellum/{types/workflow_event_display_context.py → resources/folder_entities/raw_client.py} +1 -1
  818. vellum/resources/integration_auth_configs/__init__.py +3 -0
  819. vellum/resources/integration_auth_configs/client.py +3 -0
  820. vellum/resources/integration_auth_configs/raw_client.py +3 -0
  821. vellum/resources/integration_providers/__init__.py +3 -0
  822. vellum/resources/integration_providers/client.py +3 -0
  823. vellum/resources/integration_providers/raw_client.py +3 -0
  824. vellum/resources/integrations/__init__.py +3 -0
  825. vellum/resources/integrations/client.py +3 -0
  826. vellum/resources/integrations/raw_client.py +3 -0
  827. vellum/resources/metric_definitions/raw_client.py +3 -0
  828. vellum/resources/ml_models/raw_client.py +3 -0
  829. vellum/resources/organizations/raw_client.py +3 -0
  830. vellum/resources/prompts/raw_client.py +3 -0
  831. vellum/resources/sandboxes/raw_client.py +3 -0
  832. vellum/resources/test_suite_runs/raw_client.py +3 -0
  833. vellum/resources/test_suites/raw_client.py +3 -0
  834. vellum/resources/uploaded_files/__init__.py +3 -0
  835. vellum/resources/uploaded_files/client.py +3 -0
  836. vellum/resources/uploaded_files/raw_client.py +3 -0
  837. vellum/resources/workflow_deployments/raw_client.py +3 -0
  838. vellum/resources/workflow_executions/__init__.py +3 -0
  839. vellum/resources/workflow_executions/client.py +3 -0
  840. vellum/resources/workflow_executions/raw_client.py +3 -0
  841. vellum/resources/workflow_sandboxes/raw_client.py +3 -0
  842. vellum/resources/workflows/raw_client.py +3 -0
  843. vellum/resources/workspace_secrets/raw_client.py +3 -0
  844. vellum/resources/workspaces/raw_client.py +3 -0
  845. vellum/types/api_actor_type_enum.py +3 -0
  846. vellum/types/audio_input.py +3 -0
  847. vellum/types/audio_input_request.py +3 -0
  848. vellum/types/auth_type_enum.py +3 -0
  849. vellum/types/build_status_enum.py +3 -0
  850. vellum/types/components_schemas_composio_execute_tool_request.py +3 -0
  851. vellum/types/components_schemas_composio_execute_tool_response.py +3 -0
  852. vellum/types/components_schemas_composio_integration_exec_config.py +3 -0
  853. vellum/types/components_schemas_composio_tool_definition.py +3 -0
  854. vellum/types/components_schemas_prompt_version_build_config_sandbox.py +3 -0
  855. vellum/types/components_schemas_slim_composio_tool_definition.py +3 -0
  856. vellum/types/composio_execute_tool_request.py +3 -0
  857. vellum/types/composio_execute_tool_response.py +3 -0
  858. vellum/types/composio_integration_exec_config.py +3 -0
  859. vellum/types/composio_tool_definition.py +3 -0
  860. vellum/types/container_image_build_config.py +3 -0
  861. vellum/types/create_workflow_event_request.py +3 -0
  862. vellum/types/dataset_row_push_request.py +3 -0
  863. vellum/types/delimiter_chunker_config.py +3 -0
  864. vellum/types/delimiter_chunker_config_request.py +3 -0
  865. vellum/types/delimiter_chunking.py +3 -0
  866. vellum/types/delimiter_chunking_request.py +3 -0
  867. vellum/types/deprecated_prompt_request_input.py +3 -0
  868. vellum/types/document_input.py +3 -0
  869. vellum/types/document_input_request.py +3 -0
  870. vellum/types/environment_display_config.py +3 -0
  871. vellum/types/environment_read.py +3 -0
  872. vellum/types/error_detail_response.py +3 -0
  873. vellum/types/event_create_response.py +3 -0
  874. vellum/types/execute_api_response_json.py +3 -0
  875. vellum/types/execute_workflow_async_response.py +3 -0
  876. vellum/types/execution_audio_vellum_value.py +3 -0
  877. vellum/types/execution_document_vellum_value.py +3 -0
  878. vellum/types/execution_image_vellum_value.py +3 -0
  879. vellum/types/execution_thinking_vellum_value.py +3 -0
  880. vellum/types/execution_video_vellum_value.py +3 -0
  881. vellum/types/external_parent_context.py +3 -0
  882. vellum/types/fast_embed_vectorizer_baai_bge_small_en_v_15.py +3 -0
  883. vellum/types/fast_embed_vectorizer_baai_bge_small_en_v_15_request.py +3 -0
  884. vellum/types/folder_entity_dataset.py +3 -0
  885. vellum/types/folder_entity_dataset_data.py +3 -0
  886. vellum/types/google_vertex_ai_vectorizer_gemini_embedding_001.py +3 -0
  887. vellum/types/google_vertex_ai_vectorizer_gemini_embedding_001_request.py +3 -0
  888. vellum/types/image_input.py +3 -0
  889. vellum/types/image_input_request.py +3 -0
  890. vellum/types/integration.py +3 -0
  891. vellum/types/integration_auth_config_integration.py +3 -0
  892. vellum/types/integration_auth_config_integration_credential.py +3 -0
  893. vellum/types/integration_credential_access_type.py +3 -0
  894. vellum/types/integration_name.py +3 -0
  895. vellum/types/integration_provider.py +3 -0
  896. vellum/types/integration_read.py +3 -0
  897. vellum/types/integration_trigger_context.py +3 -0
  898. vellum/types/named_scenario_input_audio_variable_value_request.py +3 -0
  899. vellum/types/named_scenario_input_document_variable_value_request.py +3 -0
  900. vellum/types/named_scenario_input_image_variable_value_request.py +3 -0
  901. vellum/types/named_scenario_input_video_variable_value_request.py +3 -0
  902. vellum/types/named_test_case_audio_variable_value.py +3 -0
  903. vellum/types/named_test_case_audio_variable_value_request.py +3 -0
  904. vellum/types/named_test_case_document_variable_value.py +3 -0
  905. vellum/types/named_test_case_document_variable_value_request.py +3 -0
  906. vellum/types/named_test_case_image_variable_value.py +3 -0
  907. vellum/types/named_test_case_image_variable_value_request.py +3 -0
  908. vellum/types/named_test_case_video_variable_value.py +3 -0
  909. vellum/types/named_test_case_video_variable_value_request.py +3 -0
  910. vellum/types/node_input_compiled_audio_value.py +3 -0
  911. vellum/types/node_input_compiled_document_value.py +3 -0
  912. vellum/types/node_input_compiled_image_value.py +3 -0
  913. vellum/types/node_input_compiled_video_value.py +3 -0
  914. vellum/types/node_output_compiled_thinking_value.py +3 -0
  915. vellum/types/paginated_slim_integration_auth_config_read_list.py +3 -0
  916. vellum/types/paginated_slim_integration_read_list.py +3 -0
  917. vellum/types/paginated_slim_tool_definition_list.py +3 -0
  918. vellum/types/paginated_workflow_deployment_release_list.py +3 -0
  919. vellum/types/private_vectorizer.py +3 -0
  920. vellum/types/private_vectorizer_request.py +3 -0
  921. vellum/types/prompt_push_response.py +3 -0
  922. vellum/types/prompt_request_audio_input.py +3 -0
  923. vellum/types/prompt_request_document_input.py +3 -0
  924. vellum/types/prompt_request_image_input.py +3 -0
  925. vellum/types/prompt_request_video_input.py +3 -0
  926. vellum/types/prompt_version_build_config_sandbox.py +3 -0
  927. vellum/types/scenario_input_audio_variable_value.py +3 -0
  928. vellum/types/scenario_input_document_variable_value.py +3 -0
  929. vellum/types/scenario_input_image_variable_value.py +3 -0
  930. vellum/types/scenario_input_video_variable_value.py +3 -0
  931. vellum/types/scheduled_trigger_context.py +3 -0
  932. vellum/types/slim_composio_tool_definition.py +3 -0
  933. vellum/types/slim_integration_auth_config_read.py +3 -0
  934. vellum/types/slim_integration_read.py +3 -0
  935. vellum/types/test_case_audio_variable_value.py +3 -0
  936. vellum/types/test_case_document_variable_value.py +3 -0
  937. vellum/types/test_case_image_variable_value.py +3 -0
  938. vellum/types/test_case_video_variable_value.py +3 -0
  939. vellum/types/thinking_vellum_value.py +3 -0
  940. vellum/types/thinking_vellum_value_request.py +3 -0
  941. vellum/types/update_active_workspace_response.py +3 -0
  942. vellum/types/uploaded_file_read.py +3 -0
  943. vellum/types/vellum_video.py +3 -0
  944. vellum/types/vellum_video_request.py +3 -0
  945. vellum/types/video_chat_message_content.py +3 -0
  946. vellum/types/video_chat_message_content_request.py +3 -0
  947. vellum/types/video_input.py +3 -0
  948. vellum/types/video_input_request.py +3 -0
  949. vellum/types/video_prompt_block.py +3 -0
  950. vellum/types/video_vellum_value.py +3 -0
  951. vellum/types/video_vellum_value_request.py +3 -0
  952. vellum/types/workflow_deployment_display_data.py +3 -0
  953. vellum/types/workflow_display_icon.py +3 -0
  954. vellum/types/workflow_event.py +3 -0
  955. vellum/types/workflow_execution_detail.py +3 -0
  956. vellum/types/workflow_execution_usage_calculation_error.py +3 -0
  957. vellum/types/workflow_execution_usage_calculation_error_code_enum.py +3 -0
  958. vellum/types/workflow_execution_usage_result.py +3 -0
  959. vellum/types/workflow_input.py +3 -0
  960. vellum/types/workflow_output_audio.py +3 -0
  961. vellum/types/workflow_output_document.py +3 -0
  962. vellum/types/workflow_output_video.py +3 -0
  963. vellum/types/workflow_request_audio_input_request.py +3 -0
  964. vellum/types/workflow_request_document_input_request.py +3 -0
  965. vellum/types/workflow_request_image_input_request.py +3 -0
  966. vellum/types/workflow_request_video_input_request.py +3 -0
  967. vellum/types/workflow_resolved_state.py +3 -0
  968. vellum/types/workflow_result_event_state.py +3 -0
  969. vellum/types/workflow_sandbox_display_data.py +3 -0
  970. vellum/types/workspace_display_config.py +3 -0
  971. vellum/utils/files/__init__.py +18 -0
  972. vellum/utils/files/constants.py +47 -0
  973. vellum/utils/files/exceptions.py +25 -0
  974. vellum/utils/files/extensions.py +59 -0
  975. vellum/utils/files/mixin.py +109 -0
  976. vellum/utils/files/read.py +41 -0
  977. vellum/utils/files/stream.py +135 -0
  978. vellum/utils/files/tests/__init__.py +0 -0
  979. vellum/utils/files/tests/test_extensions.py +54 -0
  980. vellum/utils/files/tests/test_mixin.py +205 -0
  981. vellum/utils/files/tests/test_read.py +204 -0
  982. vellum/utils/files/tests/test_stream.py +199 -0
  983. vellum/utils/files/tests/test_upload.py +309 -0
  984. vellum/utils/files/tests/test_urls.py +252 -0
  985. vellum/utils/files/types.py +8 -0
  986. vellum/utils/files/upload.py +151 -0
  987. vellum/utils/files/urls.py +71 -0
  988. vellum/utils/json_encoder.py +95 -0
  989. vellum/utils/templating/custom_filters.py +4 -4
  990. vellum/utils/templating/render.py +4 -4
  991. vellum/utils/tests/__init__.py +0 -0
  992. vellum/utils/tests/test_json_encoder.py +92 -0
  993. vellum/utils/vellum_client.py +40 -0
  994. vellum/workflows/__init__.py +78 -0
  995. vellum/workflows/constants.py +7 -0
  996. vellum/workflows/context.py +27 -9
  997. vellum/workflows/descriptors/base.py +83 -2
  998. vellum/workflows/descriptors/exceptions.py +18 -1
  999. vellum/workflows/descriptors/tests/test_utils.py +57 -0
  1000. vellum/workflows/descriptors/utils.py +27 -3
  1001. vellum/workflows/edges/__init__.py +2 -0
  1002. vellum/workflows/edges/trigger_edge.py +67 -0
  1003. vellum/workflows/emitters/__init__.py +2 -0
  1004. vellum/workflows/emitters/base.py +25 -0
  1005. vellum/workflows/emitters/vellum_emitter.py +150 -0
  1006. vellum/workflows/environment/__init__.py +2 -1
  1007. vellum/workflows/environment/environment.py +10 -3
  1008. vellum/workflows/errors/types.py +29 -2
  1009. vellum/workflows/events/__init__.py +2 -0
  1010. vellum/workflows/events/context.py +90 -0
  1011. vellum/workflows/events/exception_handling.py +58 -0
  1012. vellum/workflows/events/node.py +27 -11
  1013. vellum/workflows/events/relational_threads.py +41 -0
  1014. vellum/workflows/events/stream.py +28 -0
  1015. vellum/workflows/events/tests/test_basic_workflow.py +50 -0
  1016. vellum/workflows/events/tests/test_event.py +145 -20
  1017. vellum/workflows/events/types.py +32 -4
  1018. vellum/workflows/events/workflow.py +111 -8
  1019. vellum/workflows/exceptions.py +46 -7
  1020. vellum/workflows/executable.py +9 -0
  1021. vellum/workflows/expressions/accessor.py +65 -11
  1022. vellum/workflows/expressions/add.py +41 -0
  1023. vellum/workflows/expressions/comparison_utils.py +38 -0
  1024. vellum/workflows/expressions/concat.py +35 -0
  1025. vellum/workflows/expressions/contains.py +7 -0
  1026. vellum/workflows/expressions/greater_than.py +8 -1
  1027. vellum/workflows/expressions/greater_than_or_equal_to.py +8 -1
  1028. vellum/workflows/expressions/is_error.py +23 -0
  1029. vellum/workflows/expressions/length.py +46 -0
  1030. vellum/workflows/expressions/less_than.py +8 -1
  1031. vellum/workflows/expressions/less_than_or_equal_to.py +8 -1
  1032. vellum/workflows/expressions/minus.py +41 -0
  1033. vellum/workflows/expressions/tests/test_accessor.py +248 -0
  1034. vellum/workflows/expressions/tests/test_add.py +72 -0
  1035. vellum/workflows/expressions/tests/test_concat.py +108 -0
  1036. vellum/workflows/expressions/tests/test_contains.py +175 -0
  1037. vellum/workflows/expressions/tests/test_expressions.py +145 -32
  1038. vellum/workflows/expressions/tests/test_length.py +38 -0
  1039. vellum/workflows/expressions/tests/test_minus.py +109 -0
  1040. vellum/workflows/graph/graph.py +255 -8
  1041. vellum/workflows/graph/tests/test_graph.py +300 -0
  1042. vellum/workflows/inputs/__init__.py +2 -0
  1043. vellum/workflows/inputs/base.py +75 -18
  1044. vellum/workflows/inputs/dataset_row.py +81 -0
  1045. vellum/workflows/inputs/tests/test_inputs.py +196 -1
  1046. vellum/workflows/integrations/__init__.py +5 -0
  1047. vellum/workflows/integrations/composio_service.py +158 -0
  1048. vellum/workflows/integrations/mcp_service.py +282 -0
  1049. vellum/workflows/integrations/tests/__init__.py +0 -0
  1050. vellum/workflows/integrations/tests/test_mcp_service.py +273 -0
  1051. vellum/workflows/integrations/tests/test_vellum_integration_service.py +299 -0
  1052. vellum/workflows/integrations/vellum_integration_service.py +136 -0
  1053. vellum/workflows/loaders/__init__.py +3 -0
  1054. vellum/workflows/loaders/base.py +36 -0
  1055. vellum/workflows/nodes/__init__.py +2 -0
  1056. vellum/workflows/nodes/bases/base.py +238 -46
  1057. vellum/workflows/nodes/bases/base_adornment_node.py +64 -1
  1058. vellum/workflows/nodes/bases/tests/test_base_adornment_node.py +31 -0
  1059. vellum/workflows/nodes/bases/tests/test_base_node.py +100 -4
  1060. vellum/workflows/nodes/core/error_node/node.py +11 -2
  1061. vellum/workflows/nodes/core/inline_subworkflow_node/node.py +29 -3
  1062. vellum/workflows/nodes/core/inline_subworkflow_node/tests/test_node.py +35 -0
  1063. vellum/workflows/nodes/core/map_node/node.py +103 -90
  1064. vellum/workflows/nodes/core/map_node/tests/test_node.py +178 -0
  1065. vellum/workflows/nodes/core/retry_node/node.py +8 -1
  1066. vellum/workflows/nodes/core/retry_node/tests/test_node.py +2 -3
  1067. vellum/workflows/nodes/core/templating_node/node.py +7 -2
  1068. vellum/workflows/nodes/core/templating_node/tests/test_templating_node.py +194 -1
  1069. vellum/workflows/nodes/displayable/__init__.py +6 -0
  1070. vellum/workflows/nodes/displayable/api_node/node.py +17 -1
  1071. vellum/workflows/nodes/displayable/api_node/tests/test_api_node.py +177 -3
  1072. vellum/workflows/nodes/displayable/bases/api_node/node.py +70 -16
  1073. vellum/workflows/nodes/displayable/bases/api_node/tests/__init__.py +0 -0
  1074. vellum/workflows/nodes/displayable/bases/api_node/tests/test_node.py +150 -0
  1075. vellum/workflows/nodes/displayable/bases/base_prompt_node/node.py +68 -7
  1076. vellum/workflows/nodes/displayable/bases/inline_prompt_node/node.py +299 -27
  1077. vellum/workflows/nodes/displayable/bases/inline_prompt_node/tests/test_inline_prompt_node.py +663 -20
  1078. vellum/workflows/nodes/displayable/bases/prompt_deployment_node.py +84 -14
  1079. vellum/workflows/nodes/displayable/bases/search_node.py +26 -3
  1080. vellum/workflows/nodes/displayable/bases/tests/test_prompt_deployment_node.py +90 -0
  1081. vellum/workflows/nodes/displayable/bases/utils.py +82 -5
  1082. vellum/workflows/nodes/displayable/code_execution_node/node.py +46 -15
  1083. vellum/workflows/nodes/displayable/code_execution_node/tests/{test_code_execution_node.py → test_node.py} +646 -5
  1084. vellum/workflows/nodes/displayable/code_execution_node/utils.py +28 -74
  1085. vellum/workflows/nodes/displayable/conditional_node/node.py +8 -4
  1086. vellum/workflows/nodes/displayable/final_output_node/node.py +80 -1
  1087. vellum/workflows/nodes/displayable/final_output_node/tests/test_node.py +96 -1
  1088. vellum/workflows/nodes/displayable/guardrail_node/node.py +25 -5
  1089. vellum/workflows/nodes/displayable/guardrail_node/test_node.py +29 -0
  1090. vellum/workflows/nodes/displayable/inline_prompt_node/node.py +9 -36
  1091. vellum/workflows/nodes/displayable/inline_prompt_node/tests/test_node.py +3 -0
  1092. vellum/workflows/nodes/displayable/merge_node/node.py +8 -1
  1093. vellum/workflows/nodes/displayable/note_node/node.py +8 -1
  1094. vellum/workflows/nodes/displayable/prompt_deployment_node/node.py +7 -23
  1095. vellum/workflows/nodes/displayable/search_node/node.py +18 -0
  1096. vellum/workflows/nodes/displayable/search_node/tests/test_node.py +76 -0
  1097. vellum/workflows/nodes/displayable/set_state_node/__init__.py +5 -0
  1098. vellum/workflows/nodes/displayable/set_state_node/node.py +71 -0
  1099. vellum/workflows/nodes/displayable/set_state_node/tests/__init__.py +0 -0
  1100. vellum/workflows/nodes/displayable/set_state_node/tests/test_node.py +212 -0
  1101. vellum/workflows/nodes/displayable/subworkflow_deployment_node/node.py +220 -59
  1102. vellum/workflows/nodes/displayable/subworkflow_deployment_node/tests/test_node.py +26 -1
  1103. vellum/workflows/nodes/displayable/tests/test_inline_text_prompt_node.py +4 -1
  1104. vellum/workflows/nodes/displayable/tests/test_search_node_error_handling.py +329 -0
  1105. vellum/workflows/nodes/displayable/tests/test_text_prompt_deployment_node.py +10 -16
  1106. vellum/workflows/nodes/displayable/tool_calling_node/__init__.py +3 -0
  1107. vellum/workflows/nodes/displayable/tool_calling_node/node.py +225 -0
  1108. vellum/workflows/nodes/displayable/tool_calling_node/state.py +11 -0
  1109. vellum/workflows/nodes/displayable/tool_calling_node/tests/__init__.py +0 -0
  1110. vellum/workflows/nodes/displayable/tool_calling_node/tests/test_composio_service.py +219 -0
  1111. vellum/workflows/nodes/displayable/tool_calling_node/tests/test_node.py +802 -0
  1112. vellum/workflows/nodes/displayable/tool_calling_node/tests/test_utils.py +316 -0
  1113. vellum/workflows/nodes/displayable/tool_calling_node/utils.py +633 -0
  1114. vellum/workflows/nodes/displayable/web_search_node/__init__.py +3 -0
  1115. vellum/workflows/nodes/displayable/web_search_node/node.py +136 -0
  1116. vellum/workflows/nodes/displayable/web_search_node/tests/__init__.py +0 -0
  1117. vellum/workflows/nodes/displayable/web_search_node/tests/test_node.py +246 -0
  1118. vellum/workflows/nodes/experimental/__init__.py +1 -0
  1119. vellum/workflows/nodes/mocks.py +40 -9
  1120. vellum/workflows/nodes/tests/test_mocks.py +2 -2
  1121. vellum/workflows/nodes/tests/test_utils.py +42 -26
  1122. vellum/workflows/nodes/utils.py +70 -7
  1123. vellum/workflows/outputs/base.py +53 -12
  1124. vellum/workflows/ports/node_ports.py +6 -2
  1125. vellum/workflows/ports/port.py +28 -3
  1126. vellum/workflows/ports/tests/test_port.py +45 -0
  1127. vellum/workflows/ports/utils.py +70 -17
  1128. vellum/workflows/references/__init__.py +2 -0
  1129. vellum/workflows/references/constant.py +4 -1
  1130. vellum/workflows/references/environment_variable.py +27 -9
  1131. vellum/workflows/references/output.py +3 -5
  1132. vellum/workflows/references/trigger.py +77 -0
  1133. vellum/workflows/references/workflow_input.py +5 -1
  1134. vellum/workflows/resolvers/base.py +19 -1
  1135. vellum/workflows/resolvers/resolver.py +71 -0
  1136. vellum/workflows/resolvers/tests/test_resolver.py +168 -0
  1137. vellum/workflows/resolvers/types.py +11 -0
  1138. vellum/workflows/runner/runner.py +659 -154
  1139. vellum/workflows/sandbox.py +55 -9
  1140. vellum/workflows/state/base.py +192 -64
  1141. vellum/workflows/state/context.py +225 -6
  1142. vellum/workflows/state/delta.py +20 -0
  1143. vellum/workflows/state/encoder.py +2 -62
  1144. vellum/workflows/state/tests/test_state.py +24 -9
  1145. vellum/workflows/tests/test_dataset_row.py +190 -0
  1146. vellum/workflows/tests/test_sandbox.py +137 -0
  1147. vellum/workflows/tests/triggers/test_integration_trigger.py +156 -0
  1148. vellum/workflows/triggers/__init__.py +6 -0
  1149. vellum/workflows/triggers/base.py +391 -0
  1150. vellum/workflows/triggers/integration.py +186 -0
  1151. vellum/workflows/triggers/manual.py +37 -0
  1152. vellum/workflows/triggers/schedule.py +18 -0
  1153. vellum/workflows/triggers/tests/__init__.py +1 -0
  1154. vellum/workflows/triggers/tests/test_base_trigger_display.py +147 -0
  1155. vellum/workflows/triggers/tests/test_integration.py +155 -0
  1156. vellum/workflows/types/__init__.py +2 -1
  1157. vellum/workflows/types/code_execution_node_wrappers.py +105 -0
  1158. vellum/workflows/types/core.py +5 -0
  1159. vellum/workflows/types/definition.py +168 -2
  1160. vellum/workflows/types/generics.py +5 -0
  1161. vellum/workflows/types/tests/test_definition.py +183 -0
  1162. vellum/workflows/types/tests/test_utils.py +14 -3
  1163. vellum/workflows/types/utils.py +64 -13
  1164. vellum/workflows/utils/files.py +28 -0
  1165. vellum/workflows/utils/functions.py +284 -17
  1166. vellum/workflows/utils/hmac.py +44 -0
  1167. vellum/workflows/utils/names.py +32 -4
  1168. vellum/workflows/utils/pydantic_schema.py +38 -0
  1169. vellum/workflows/utils/tests/test_functions.py +516 -5
  1170. vellum/workflows/utils/tests/test_names.py +9 -0
  1171. vellum/workflows/utils/tests/test_vellum_variables.py +32 -2
  1172. vellum/workflows/utils/uuids.py +35 -0
  1173. vellum/workflows/utils/vellum_variables.py +131 -7
  1174. vellum/workflows/utils/zip.py +46 -0
  1175. vellum/workflows/vellum_client.py +3 -21
  1176. vellum/workflows/workflows/base.py +363 -39
  1177. vellum/workflows/workflows/event_filters.py +13 -0
  1178. vellum/workflows/workflows/tests/test_base_workflow.py +122 -10
  1179. vellum/workflows/workflows/tests/test_event_filters.py +126 -0
  1180. {vellum_ai-0.14.41.dist-info → vellum_ai-1.11.2.dist-info}/METADATA +12 -13
  1181. vellum_ai-1.11.2.dist-info/RECORD +2177 -0
  1182. vellum_ai-1.11.2.dist-info/entry_points.txt +4 -0
  1183. vellum_cli/__init__.py +42 -4
  1184. vellum_cli/config.py +12 -5
  1185. vellum_cli/image_push.py +120 -10
  1186. vellum_cli/logger.py +11 -0
  1187. vellum_cli/move.py +56 -0
  1188. vellum_cli/ping.py +6 -0
  1189. vellum_cli/pull.py +78 -14
  1190. vellum_cli/push.py +149 -61
  1191. vellum_cli/tests/conftest.py +6 -0
  1192. vellum_cli/tests/test_image_push.py +295 -8
  1193. vellum_cli/tests/test_image_push_error_handling.py +258 -0
  1194. vellum_cli/tests/test_init.py +7 -24
  1195. vellum_cli/tests/test_move.py +154 -0
  1196. vellum_cli/tests/test_ping.py +15 -0
  1197. vellum_cli/tests/test_pull.py +133 -57
  1198. vellum_cli/tests/test_push.py +708 -19
  1199. vellum_ee/assets/node-definitions.json +1135 -0
  1200. vellum_ee/scripts/generate_node_definitions.py +89 -0
  1201. vellum_ee/workflows/display/base.py +29 -55
  1202. vellum_ee/workflows/display/editor/types.py +3 -0
  1203. vellum_ee/workflows/display/exceptions.py +3 -0
  1204. vellum_ee/workflows/display/nodes/base_node_display.py +211 -218
  1205. vellum_ee/workflows/display/nodes/get_node_display_class.py +1 -25
  1206. vellum_ee/workflows/display/nodes/tests/test_base_node_display.py +149 -3
  1207. vellum_ee/workflows/display/nodes/vellum/__init__.py +2 -0
  1208. vellum_ee/workflows/display/nodes/vellum/api_node.py +37 -12
  1209. vellum_ee/workflows/display/nodes/vellum/base_adornment_node.py +3 -3
  1210. vellum_ee/workflows/display/nodes/vellum/code_execution_node.py +30 -8
  1211. vellum_ee/workflows/display/nodes/vellum/conditional_node.py +19 -7
  1212. vellum_ee/workflows/display/nodes/vellum/error_node.py +23 -19
  1213. vellum_ee/workflows/display/nodes/vellum/final_output_node.py +9 -19
  1214. vellum_ee/workflows/display/nodes/vellum/function_node.py +14 -0
  1215. vellum_ee/workflows/display/nodes/vellum/guardrail_node.py +4 -4
  1216. vellum_ee/workflows/display/nodes/vellum/inline_prompt_node.py +114 -29
  1217. vellum_ee/workflows/display/nodes/vellum/inline_subworkflow_node.py +35 -9
  1218. vellum_ee/workflows/display/nodes/vellum/map_node.py +44 -25
  1219. vellum_ee/workflows/display/nodes/vellum/merge_node.py +2 -4
  1220. vellum_ee/workflows/display/nodes/vellum/note_node.py +2 -3
  1221. vellum_ee/workflows/display/nodes/vellum/prompt_deployment_node.py +28 -17
  1222. vellum_ee/workflows/display/nodes/vellum/retry_node.py +6 -7
  1223. vellum_ee/workflows/display/nodes/vellum/search_node.py +84 -18
  1224. vellum_ee/workflows/display/nodes/vellum/subworkflow_deployment_node.py +26 -14
  1225. vellum_ee/workflows/display/nodes/vellum/templating_node.py +5 -5
  1226. vellum_ee/workflows/display/nodes/vellum/tests/test_api_node.py +65 -0
  1227. vellum_ee/workflows/display/nodes/vellum/tests/test_code_execution_node.py +219 -3
  1228. vellum_ee/workflows/display/nodes/vellum/tests/test_error_node.py +4 -0
  1229. vellum_ee/workflows/display/nodes/vellum/tests/test_final_output_node.py +80 -0
  1230. vellum_ee/workflows/display/nodes/vellum/tests/test_inline_subworkflow_node.py +88 -0
  1231. vellum_ee/workflows/display/nodes/vellum/tests/test_prompt_deployment_node.py +177 -0
  1232. vellum_ee/workflows/display/nodes/vellum/tests/test_prompt_node.py +207 -6
  1233. vellum_ee/workflows/display/nodes/vellum/tests/test_retry_node.py +1 -1
  1234. vellum_ee/workflows/display/nodes/vellum/tests/test_search_node.py +104 -0
  1235. vellum_ee/workflows/display/nodes/vellum/tests/test_subworkflow_deployment_node.py +110 -0
  1236. vellum_ee/workflows/display/nodes/vellum/tests/test_templating_node.py +2 -2
  1237. vellum_ee/workflows/display/nodes/vellum/tests/test_tool_calling_node.py +694 -0
  1238. vellum_ee/workflows/display/nodes/vellum/tests/test_try_node.py +2 -2
  1239. vellum_ee/workflows/display/nodes/vellum/tests/test_utils.py +8 -9
  1240. vellum_ee/workflows/display/nodes/vellum/try_node.py +6 -7
  1241. vellum_ee/workflows/display/tests/test_base_workflow_display.py +427 -8
  1242. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/conftest.py +2 -2
  1243. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/test_adornments_serialization.py +150 -125
  1244. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/test_attributes_serialization.py +277 -87
  1245. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/test_outputs_serialization.py +21 -17
  1246. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/test_ports_serialization.py +76 -64
  1247. vellum_ee/workflows/display/tests/workflow_serialization/generic_nodes/test_trigger_serialization.py +69 -12
  1248. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_api_node_serialization.py +68 -46
  1249. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_code_execution_node_serialization.py +92 -80
  1250. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_conditional_node_serialization.py +320 -170
  1251. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_default_state_serialization.py +14 -15
  1252. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_error_node_serialization.py +14 -12
  1253. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_generic_node_serialization.py +28 -18
  1254. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_guardrail_node_serialization.py +20 -16
  1255. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_inline_prompt_node_serialization.py +621 -5
  1256. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_inline_subworkflow_serialization.py +73 -43
  1257. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_map_node_serialization.py +51 -32
  1258. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_merge_node_serialization.py +37 -33
  1259. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_prompt_deployment_serialization.py +367 -36
  1260. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_search_node_serialization.py +40 -36
  1261. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_set_state_node_serialization.py +86 -0
  1262. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_subworkflow_deployment_serialization.py +25 -21
  1263. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_templating_node_serialization.py +22 -18
  1264. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_terminal_node_serialization.py +14 -10
  1265. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_composio_serialization.py +87 -0
  1266. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_inline_workflow_serialization.py +313 -0
  1267. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_mcp_serialization.py +65 -0
  1268. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_parent_input.py +89 -0
  1269. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_serialization.py +224 -0
  1270. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_vellum_integration_serialization.py +68 -0
  1271. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_tool_calling_node_workflow_deployment_serialization.py +107 -0
  1272. vellum_ee/workflows/display/tests/workflow_serialization/test_basic_try_node_serialization.py +2 -3
  1273. vellum_ee/workflows/display/tests/workflow_serialization/test_chat_message_dict_reference_serialization.py +108 -0
  1274. vellum_ee/workflows/display/tests/workflow_serialization/test_complex_terminal_node_serialization.py +20 -65
  1275. vellum_ee/workflows/display/tests/workflow_serialization/test_final_output_node_map_reference_serialization.py +88 -0
  1276. vellum_ee/workflows/display/tests/workflow_serialization/test_integration_trigger_serialization.py +306 -0
  1277. vellum_ee/workflows/display/tests/workflow_serialization/test_integration_trigger_with_entrypoint_node_id.py +88 -0
  1278. vellum_ee/workflows/display/tests/workflow_serialization/test_list_vellum_document_serialization.py +65 -0
  1279. vellum_ee/workflows/display/tests/workflow_serialization/test_manual_trigger_serialization.py +110 -0
  1280. vellum_ee/workflows/display/tests/workflow_serialization/test_map_node_with_terminal_nodes_serialization.py +62 -0
  1281. vellum_ee/workflows/display/tests/workflow_serialization/test_multi_trigger_same_node_serialization.py +99 -0
  1282. vellum_ee/workflows/display/tests/workflow_serialization/test_scheduled_trigger_serialization.py +267 -0
  1283. vellum_ee/workflows/display/tests/workflow_serialization/test_terminal_node_any_serialization.py +49 -0
  1284. vellum_ee/workflows/display/tests/workflow_serialization/test_trigger_display_from_display_class.py +153 -0
  1285. vellum_ee/workflows/display/tests/workflow_serialization/test_web_search_node_serialization.py +72 -0
  1286. vellum_ee/workflows/display/tests/workflow_serialization/test_workflow_input_parameterization_error.py +37 -0
  1287. vellum_ee/workflows/display/types.py +32 -2
  1288. vellum_ee/workflows/display/utils/auto_layout.py +130 -0
  1289. vellum_ee/workflows/display/utils/events.py +57 -0
  1290. vellum_ee/workflows/display/utils/exceptions.py +19 -0
  1291. vellum_ee/workflows/display/utils/expressions.py +487 -2
  1292. vellum_ee/workflows/display/utils/metadata.py +146 -0
  1293. vellum_ee/workflows/display/utils/registry.py +46 -0
  1294. vellum_ee/workflows/display/utils/tests/__init__.py +0 -0
  1295. vellum_ee/workflows/display/utils/tests/test_auto_layout.py +56 -0
  1296. vellum_ee/workflows/display/utils/tests/test_events.py +185 -0
  1297. vellum_ee/workflows/display/utils/tests/test_expressions.py +92 -0
  1298. vellum_ee/workflows/display/utils/vellum.py +49 -86
  1299. vellum_ee/workflows/display/vellum.py +2 -128
  1300. vellum_ee/workflows/display/workflows/__init__.py +0 -1
  1301. vellum_ee/workflows/display/workflows/base_workflow_display.py +778 -129
  1302. vellum_ee/workflows/display/workflows/get_vellum_workflow_display_class.py +3 -0
  1303. vellum_ee/workflows/display/workflows/tests/test_workflow_display.py +752 -2
  1304. vellum_ee/workflows/server/virtual_file_loader.py +131 -6
  1305. vellum_ee/workflows/tests/local_workflow/display/nodes/final_output.py +1 -1
  1306. vellum_ee/workflows/tests/local_workflow/display/nodes/templating_node.py +1 -1
  1307. vellum_ee/workflows/tests/local_workflow/display/workflow.py +11 -14
  1308. vellum_ee/workflows/tests/test_display_meta.py +89 -0
  1309. vellum_ee/workflows/tests/test_registry.py +169 -0
  1310. vellum_ee/workflows/tests/test_serialize_module.py +265 -0
  1311. vellum_ee/workflows/tests/test_server.py +619 -44
  1312. vellum_ee/workflows/tests/test_virtual_files.py +48 -0
  1313. vellum/client/resources/release_reviews/client.py +0 -254
  1314. vellum/client/types/node_event_display_context.py +0 -30
  1315. vellum/client/types/workflow_event_display_context.py +0 -28
  1316. vellum/workflows/nodes/experimental/openai_chat_completion_node/__init__.py +0 -5
  1317. vellum/workflows/nodes/experimental/openai_chat_completion_node/node.py +0 -266
  1318. vellum/workflows/nodes/experimental/tool_calling_node/__init__.py +0 -3
  1319. vellum/workflows/nodes/experimental/tool_calling_node/node.py +0 -125
  1320. vellum/workflows/nodes/experimental/tool_calling_node/utils.py +0 -128
  1321. vellum_ai-0.14.41.dist-info/RECORD +0 -1704
  1322. vellum_ai-0.14.41.dist-info/entry_points.txt +0 -3
  1323. vellum_ee/workflows/display/workflows/vellum_workflow_display.py +0 -9
  1324. /vellum/{workflows/nodes/displayable/bases/inline_prompt_node → prompts}/constants.py +0 -0
  1325. {vellum_ai-0.14.41.dist-info → vellum_ai-1.11.2.dist-info}/LICENSE +0 -0
  1326. {vellum_ai-0.14.41.dist-info → vellum_ai-1.11.2.dist-info}/WHEEL +0 -0
@@ -0,0 +1,802 @@
1
+ import pytest
2
+ import json
3
+ from unittest import mock
4
+ from uuid import uuid4
5
+ from typing import Any, Iterator, List, cast
6
+
7
+ from vellum import ChatMessage
8
+ from vellum.client.core.api_error import ApiError
9
+ from vellum.client.types.execute_prompt_event import ExecutePromptEvent
10
+ from vellum.client.types.fulfilled_execute_prompt_event import FulfilledExecutePromptEvent
11
+ from vellum.client.types.function_call import FunctionCall
12
+ from vellum.client.types.function_call_vellum_value import FunctionCallVellumValue
13
+ from vellum.client.types.initiated_execute_prompt_event import InitiatedExecutePromptEvent
14
+ from vellum.client.types.prompt_output import PromptOutput
15
+ from vellum.client.types.string_chat_message_content import StringChatMessageContent
16
+ from vellum.client.types.string_vellum_value import StringVellumValue
17
+ from vellum.client.types.variable_prompt_block import VariablePromptBlock
18
+ from vellum.prompts.constants import DEFAULT_PROMPT_PARAMETERS
19
+ from vellum.workflows import BaseWorkflow
20
+ from vellum.workflows.constants import AuthorizationType, VellumIntegrationProviderType
21
+ from vellum.workflows.errors.types import WorkflowErrorCode
22
+ from vellum.workflows.exceptions import NodeException
23
+ from vellum.workflows.inputs.base import BaseInputs
24
+ from vellum.workflows.nodes.bases import BaseNode
25
+ from vellum.workflows.nodes.displayable.tool_calling_node.node import ToolCallingNode
26
+ from vellum.workflows.nodes.displayable.tool_calling_node.state import ToolCallingState
27
+ from vellum.workflows.nodes.displayable.tool_calling_node.utils import (
28
+ create_function_node,
29
+ create_mcp_tool_node,
30
+ create_router_node,
31
+ create_tool_prompt_node,
32
+ )
33
+ from vellum.workflows.outputs.base import BaseOutput, BaseOutputs
34
+ from vellum.workflows.ports.utils import validate_ports
35
+ from vellum.workflows.state.base import BaseState, StateMeta
36
+ from vellum.workflows.state.context import WorkflowContext
37
+ from vellum.workflows.types.definition import (
38
+ DeploymentDefinition,
39
+ MCPServer,
40
+ MCPToolDefinition,
41
+ VellumIntegrationToolDefinition,
42
+ )
43
+ from vellum.workflows.workflows.event_filters import all_workflow_event_filter
44
+
45
+
46
+ def first_function() -> str:
47
+ return "first_function"
48
+
49
+
50
+ def second_function() -> str:
51
+ return "second_function"
52
+
53
+
54
+ def test_router_node_port_ordering_with_multiple_tools():
55
+ """
56
+ Test that router node ports are created in the correct order: on_if, on_elif, ..., on_else.
57
+
58
+ This test validates the fix for the bug where multiple tools would create multiple on_if
59
+ ports instead of on_if followed by on_elif ports, which violates port validation rules.
60
+ """
61
+
62
+ # GIVEN three functions to ensure we test multiple elif cases
63
+ def third_function() -> str:
64
+ return "third_function"
65
+
66
+ # AND a tool prompt node
67
+ tool_prompt_node = create_tool_prompt_node(
68
+ ml_model="test-model",
69
+ blocks=[],
70
+ functions=[first_function, second_function, third_function],
71
+ prompt_inputs=None,
72
+ parameters=DEFAULT_PROMPT_PARAMETERS,
73
+ )
74
+
75
+ # WHEN a router node is created with multiple functions
76
+ router_node = create_router_node(
77
+ functions=[first_function, second_function, third_function],
78
+ tool_prompt_node=tool_prompt_node,
79
+ )
80
+
81
+ # THEN the first function port should be an on_if port
82
+ first_function_port = getattr(router_node.Ports, "first_function")
83
+ assert first_function_port._condition_type.value == "IF"
84
+
85
+ # AND the second function port should be an on_elif port
86
+ second_function_port = getattr(router_node.Ports, "second_function")
87
+ assert second_function_port._condition_type.value == "ELIF"
88
+
89
+ # AND the third function port should also be an on_elif port
90
+ third_function_port = getattr(router_node.Ports, "third_function")
91
+ assert third_function_port._condition_type.value == "ELIF"
92
+
93
+ # AND the default port should be an on_else port
94
+ default_port = getattr(router_node.Ports, "default")
95
+ assert default_port._condition_type.value == "ELSE"
96
+
97
+ # AND the ports should pass validation
98
+ ports = [first_function_port, second_function_port, third_function_port, default_port]
99
+ # This should not raise an exception
100
+ validate_ports(ports)
101
+
102
+
103
+ def test_port_condition_match_function_name():
104
+ """
105
+ Test that the port condition correctly matches the function name.
106
+ """
107
+ # GIVEN a tool prompt node
108
+ tool_prompt_node = create_tool_prompt_node(
109
+ ml_model="test-model",
110
+ blocks=[],
111
+ functions=[first_function, second_function],
112
+ prompt_inputs=None,
113
+ parameters=DEFAULT_PROMPT_PARAMETERS,
114
+ )
115
+
116
+ # AND a router node that references the tool prompt node
117
+ router_node = create_router_node(
118
+ functions=[first_function, second_function],
119
+ tool_prompt_node=tool_prompt_node,
120
+ )
121
+
122
+ # AND a state with a function call to the first function
123
+ state = ToolCallingState(
124
+ meta=StateMeta(
125
+ node_outputs={
126
+ tool_prompt_node.Outputs.results: [
127
+ FunctionCallVellumValue(
128
+ value=FunctionCall(
129
+ arguments={}, id="call_zp7pBQjGAOBCr7lo0AbR1HXT", name="first_function", state="FULFILLED"
130
+ ),
131
+ )
132
+ ],
133
+ },
134
+ )
135
+ )
136
+
137
+ # WHEN the port condition is resolved
138
+ # THEN the first function port should be true
139
+ first_function_port = getattr(router_node.Ports, "first_function")
140
+ assert first_function_port.resolve_condition(state) is True
141
+
142
+ # AND the second function port should be false
143
+ second_function_port = getattr(router_node.Ports, "second_function")
144
+ assert second_function_port.resolve_condition(state) is False
145
+
146
+ # AND the default port should be false
147
+ default_port = getattr(router_node.Ports, "default")
148
+ assert default_port.resolve_condition(state) is False
149
+
150
+
151
+ def test_tool_calling_node_inline_workflow_context():
152
+ """
153
+ Test that the tool calling node correctly passes the context to the inline workflow.
154
+ This specifically tests that inline workflows receive the correct context.
155
+ """
156
+
157
+ # GIVEN a test workflow that captures its context
158
+ class MyNode(BaseNode):
159
+ class Outputs(BaseOutputs):
160
+ generated_files: Any
161
+
162
+ def run(self) -> Outputs:
163
+ return self.Outputs(generated_files=self._context.generated_files)
164
+
165
+ class MyWorkflow(BaseWorkflow[BaseInputs, BaseState]):
166
+ graph = MyNode
167
+
168
+ class Outputs(BaseOutputs):
169
+ generated_files = MyNode.Outputs.generated_files
170
+
171
+ # GIVEN a tool prompt node
172
+ tool_prompt_node = create_tool_prompt_node(
173
+ ml_model="test-model",
174
+ blocks=[],
175
+ functions=[MyWorkflow],
176
+ prompt_inputs=None,
177
+ parameters=DEFAULT_PROMPT_PARAMETERS,
178
+ )
179
+
180
+ # WHEN we create a function node for the workflow
181
+ function_node_class = create_function_node(
182
+ function=MyWorkflow,
183
+ tool_prompt_node=tool_prompt_node,
184
+ )
185
+
186
+ # AND we create an instance with a context containing generated_files
187
+ function_node = function_node_class()
188
+
189
+ # Create a parent context with test data
190
+ parent_context = WorkflowContext(
191
+ generated_files={"script.py": "print('hello world')"},
192
+ )
193
+ function_node._context = parent_context
194
+
195
+ # WHEN the function node runs
196
+ outputs = list(function_node.run())
197
+
198
+ # THEN the workflow should have run successfully
199
+ assert outputs is not None
200
+
201
+ # AND the chat history should contain a function response
202
+ assert len(function_node.state.chat_history) == 1
203
+ function_response = function_node.state.chat_history[0]
204
+ assert function_response.role == "FUNCTION"
205
+
206
+ # AND the response should contain the generated files
207
+ assert isinstance(function_response.content, StringChatMessageContent)
208
+ data = json.loads(function_response.content.value)
209
+ assert data["generated_files"] == {"script.py": "print('hello world')"}
210
+
211
+
212
+ def test_deployment_definition_release_tag_defaults_to_latest():
213
+ """
214
+ Test that when creating a DeploymentDefinition without specifying release_tag,
215
+ it defaults to "LATEST".
216
+ """
217
+ # WHEN we create a deployment definition without specifying release_tag
218
+ deployment_config = DeploymentDefinition(deployment="test-deployment")
219
+
220
+ # THEN the release_tag should default to "LATEST"
221
+ assert deployment_config.release_tag == "LATEST"
222
+
223
+
224
+ def test_tool_calling_node_with_user_provided_chat_history_block(vellum_adhoc_prompt_client):
225
+ """
226
+ Test that ToolCallingNode with user-provided chat history block merges user and node messages.
227
+ """
228
+
229
+ # GIVEN a ToolCallingNode with a user-provided chat history block
230
+ user_chat_history_block = VariablePromptBlock(
231
+ block_type="VARIABLE",
232
+ input_variable="chat_history",
233
+ state=None,
234
+ cache_config=None,
235
+ )
236
+
237
+ class TestToolCallingNode(ToolCallingNode):
238
+ ml_model = "gpt-4o-mini"
239
+ blocks = [user_chat_history_block]
240
+ functions = [first_function]
241
+ prompt_inputs = {"chat_history": [ChatMessage(role="USER", text="Hello from user")]}
242
+ max_prompt_iterations = 1
243
+
244
+ def generate_prompt_events(*args: Any, **kwargs: Any) -> Iterator[Any]:
245
+ execution_id = str(uuid4())
246
+ events = [
247
+ InitiatedExecutePromptEvent(execution_id=execution_id),
248
+ FulfilledExecutePromptEvent(
249
+ execution_id=execution_id,
250
+ outputs=[StringVellumValue(value="Hello! I can help you.")],
251
+ ),
252
+ ]
253
+ yield from events
254
+
255
+ vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.side_effect = generate_prompt_events
256
+
257
+ # AND a state
258
+ state = BaseState()
259
+
260
+ # WHEN the ToolCallingNode runs
261
+ node = TestToolCallingNode(state=state)
262
+ list(node.run())
263
+
264
+ # THEN the API should be called with the correct blocks
265
+ mock_api = vellum_adhoc_prompt_client.adhoc_execute_prompt_stream
266
+ assert mock_api.call_count >= 1
267
+
268
+ # AND the blocks should include the user-provided chat_history block
269
+ call_kwargs = mock_api.call_args.kwargs
270
+ blocks = call_kwargs["blocks"]
271
+
272
+ chat_history_blocks = [
273
+ block for block in blocks if block.block_type == "VARIABLE" and block.input_variable == "chat_history"
274
+ ]
275
+ assert len(chat_history_blocks) == 1
276
+
277
+ # AND the input_values should include the user's chat history
278
+ input_values = call_kwargs["input_values"]
279
+ chat_history_inputs = [
280
+ input_val for input_val in input_values if hasattr(input_val, "key") and input_val.key == "chat_history"
281
+ ]
282
+ assert len(chat_history_inputs) == 1
283
+ assert chat_history_inputs[0].value == [ChatMessage(role="USER", text="Hello from user")]
284
+
285
+
286
+ def test_tool_calling_node_with_generic_type_parameter():
287
+ # GIVEN a custom state class
288
+ class State(BaseState):
289
+ pass
290
+
291
+ # AND a ToolCallingNode that uses the generic type parameter
292
+ class TestToolCallingNode(ToolCallingNode[State]):
293
+ ml_model = "gpt-4o-mini"
294
+ blocks = []
295
+ functions = [first_function]
296
+ max_prompt_iterations = 1
297
+
298
+ # WHEN we create an instance of the node
299
+ state = State()
300
+ node = TestToolCallingNode(state=state)
301
+
302
+ # THEN the node should be created successfully
303
+ assert node is not None
304
+ assert isinstance(node, TestToolCallingNode)
305
+ assert node.state == state
306
+
307
+
308
+ def test_tool_calling_node_workflow_is_dynamic(vellum_adhoc_prompt_client):
309
+ """
310
+ Test workflow_version_exec_config without any mocks to see if that's the issue.
311
+ """
312
+
313
+ def generate_prompt_events(*args, **kwargs) -> Iterator[ExecutePromptEvent]:
314
+ execution_id = str(uuid4())
315
+
316
+ call_count = vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.call_count
317
+ expected_outputs: List[PromptOutput]
318
+ if call_count == 1:
319
+ expected_outputs = [
320
+ FunctionCallVellumValue(
321
+ value=FunctionCall(
322
+ arguments={"var_1": 1, "var_2": 2},
323
+ id="call_123",
324
+ name="add_numbers_workflow",
325
+ state="FULFILLED",
326
+ ),
327
+ ),
328
+ ]
329
+ else:
330
+ expected_outputs = [StringVellumValue(value="The result is 3")]
331
+
332
+ events: List[ExecutePromptEvent] = [
333
+ InitiatedExecutePromptEvent(execution_id=execution_id),
334
+ FulfilledExecutePromptEvent(
335
+ execution_id=execution_id,
336
+ outputs=expected_outputs,
337
+ ),
338
+ ]
339
+ yield from events
340
+
341
+ vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.side_effect = generate_prompt_events
342
+
343
+ class AddNode(BaseNode):
344
+
345
+ class Outputs(BaseNode.Outputs):
346
+ result: int
347
+
348
+ def run(self) -> Outputs:
349
+ return self.Outputs(result=1)
350
+
351
+ class AddNumbersWorkflow(BaseWorkflow[BaseInputs, BaseState]):
352
+ """
353
+ A simple workflow that adds two numbers.
354
+ """
355
+
356
+ graph = AddNode
357
+
358
+ class Outputs(BaseWorkflow.Outputs):
359
+ result = AddNode.Outputs.result
360
+
361
+ class TestToolCallingNode(ToolCallingNode):
362
+ ml_model = "gpt-4o-mini"
363
+ blocks = []
364
+ functions = [AddNumbersWorkflow]
365
+ prompt_inputs = {}
366
+
367
+ # GIVEN a workflow with just a tool calling node
368
+ class AgentWorkflow(BaseWorkflow[BaseInputs, BaseState]):
369
+ graph = TestToolCallingNode
370
+
371
+ class Outputs(BaseWorkflow.Outputs):
372
+ text: str = TestToolCallingNode.Outputs.text
373
+ chat_history: List[ChatMessage] = TestToolCallingNode.Outputs.chat_history
374
+
375
+ workflow = AgentWorkflow()
376
+
377
+ # WHEN the workflow is executed and we capture all events
378
+ events = list(workflow.stream(event_filter=all_workflow_event_filter))
379
+
380
+ # AND we should find workflow execution initiated events
381
+ initiated_events = [event for event in events if event.name == "workflow.execution.initiated"]
382
+ assert len(initiated_events) == 3 # Main workflow + tool calling internal + inline workflow
383
+
384
+ assert initiated_events[0].body.workflow_definition.is_dynamic is False # Main workflow
385
+ assert initiated_events[1].body.workflow_definition.is_dynamic is True # Tool calling internal
386
+ assert initiated_events[2].body.workflow_definition.is_dynamic is True # Inline workflow
387
+
388
+
389
+ def test_tool_node_preserves_node_exception():
390
+ """Test that tool nodes preserve NodeException error codes and raw_data."""
391
+
392
+ def failing_function() -> str:
393
+ raise NodeException(
394
+ message="Custom error",
395
+ code=WorkflowErrorCode.INVALID_INPUTS,
396
+ raw_data={"key": "value"},
397
+ )
398
+
399
+ tool_prompt_node = create_tool_prompt_node(
400
+ ml_model="test-model",
401
+ blocks=[],
402
+ functions=[failing_function],
403
+ prompt_inputs=None,
404
+ parameters=DEFAULT_PROMPT_PARAMETERS,
405
+ )
406
+
407
+ function_node_class = create_function_node(
408
+ function=failing_function,
409
+ tool_prompt_node=tool_prompt_node,
410
+ )
411
+
412
+ state = ToolCallingState(
413
+ meta=StateMeta(
414
+ node_outputs={
415
+ tool_prompt_node.Outputs.results: [
416
+ FunctionCallVellumValue(
417
+ value=FunctionCall(
418
+ arguments={},
419
+ id="call_123",
420
+ name="failing_function",
421
+ state="FULFILLED",
422
+ ),
423
+ )
424
+ ],
425
+ },
426
+ )
427
+ )
428
+
429
+ function_node = function_node_class(state=state)
430
+
431
+ with pytest.raises(NodeException) as exc_info:
432
+ list(function_node.run())
433
+
434
+ e = exc_info.value
435
+ assert e.code == WorkflowErrorCode.INVALID_INPUTS
436
+ assert e.raw_data == {"key": "value"}
437
+ assert "Custom error" in e.message
438
+
439
+
440
+ def test_function_node_outputs_result():
441
+ """Test that FunctionNode yields output with name 'result' matching the Outputs class."""
442
+
443
+ # GIVEN a simple function that returns a value
444
+ def my_tool_function() -> str:
445
+ return "test_result"
446
+
447
+ # AND a tool prompt node with that function
448
+ tool_prompt_node = create_tool_prompt_node(
449
+ ml_model="test-model",
450
+ blocks=[],
451
+ functions=[my_tool_function],
452
+ prompt_inputs=None,
453
+ parameters=DEFAULT_PROMPT_PARAMETERS,
454
+ )
455
+
456
+ function_node_class = create_function_node(
457
+ function=my_tool_function,
458
+ tool_prompt_node=tool_prompt_node,
459
+ )
460
+
461
+ # AND a state with a function call
462
+ state = ToolCallingState(
463
+ meta=StateMeta(
464
+ node_outputs={
465
+ tool_prompt_node.Outputs.results: [
466
+ FunctionCallVellumValue(
467
+ value=FunctionCall(
468
+ arguments={},
469
+ id="call_789",
470
+ name="my_tool_function",
471
+ state="FULFILLED",
472
+ ),
473
+ )
474
+ ],
475
+ },
476
+ )
477
+ )
478
+
479
+ function_node = function_node_class(state=state)
480
+
481
+ # WHEN the function node runs
482
+ outputs = list(function_node.run())
483
+
484
+ # THEN there should be exactly one output with name "result"
485
+ assert len(outputs) == 1
486
+ result_output = outputs[0]
487
+ assert isinstance(result_output, BaseOutput)
488
+ assert result_output.name == "result"
489
+ assert result_output.is_fulfilled is True
490
+ assert result_output.value == "test_result"
491
+
492
+
493
+ def test_tool_node_error_message_includes_function_name():
494
+ """Test that error messages include the actual function name, not 'wrapper'."""
495
+
496
+ # GIVEN a function that raises a regular exception
497
+ def my_tool_function() -> str:
498
+ raise ValueError("Something went wrong")
499
+
500
+ # AND a tool prompt node with that function
501
+ tool_prompt_node = create_tool_prompt_node(
502
+ ml_model="test-model",
503
+ blocks=[],
504
+ functions=[my_tool_function],
505
+ prompt_inputs=None,
506
+ parameters=DEFAULT_PROMPT_PARAMETERS,
507
+ )
508
+
509
+ function_node_class = create_function_node(
510
+ function=my_tool_function,
511
+ tool_prompt_node=tool_prompt_node,
512
+ )
513
+
514
+ # AND a state with a function call
515
+ state = ToolCallingState(
516
+ meta=StateMeta(
517
+ node_outputs={
518
+ tool_prompt_node.Outputs.results: [
519
+ FunctionCallVellumValue(
520
+ value=FunctionCall(
521
+ arguments={},
522
+ id="call_456",
523
+ name="my_tool_function",
524
+ state="FULFILLED",
525
+ ),
526
+ )
527
+ ],
528
+ },
529
+ )
530
+ )
531
+
532
+ function_node = function_node_class(state=state)
533
+
534
+ # WHEN the function node runs and raises an exception
535
+ with pytest.raises(NodeException) as exc_info:
536
+ list(function_node.run())
537
+
538
+ # THEN the error message should include the actual function name
539
+ e = exc_info.value
540
+ assert "my_tool_function" in e.message
541
+ assert "wrapper" not in e.message.lower()
542
+ assert "Something went wrong" in e.message
543
+
544
+
545
+ def test_mcp_node_outputs_result():
546
+ """Test that MCPNode yields output with name 'result' matching the Outputs class."""
547
+
548
+ # GIVEN an MCP tool definition
549
+ mcp_server = MCPServer(
550
+ name="test_server",
551
+ url="https://test.server.com",
552
+ authorization_type=AuthorizationType.BEARER_TOKEN,
553
+ )
554
+ mcp_tool = MCPToolDefinition(
555
+ name="test_tool",
556
+ server=mcp_server,
557
+ description="A test MCP tool",
558
+ parameters={},
559
+ )
560
+
561
+ # AND a tool prompt node
562
+ tool_prompt_node = create_tool_prompt_node(
563
+ ml_model="test-model",
564
+ blocks=[],
565
+ functions=[mcp_server],
566
+ prompt_inputs=None,
567
+ parameters=DEFAULT_PROMPT_PARAMETERS,
568
+ )
569
+
570
+ mcp_node_class = create_mcp_tool_node(
571
+ tool_def=mcp_tool,
572
+ tool_prompt_node=tool_prompt_node,
573
+ )
574
+
575
+ # AND a state with a function call
576
+ state = ToolCallingState(
577
+ meta=StateMeta(
578
+ node_outputs={
579
+ tool_prompt_node.Outputs.results: [
580
+ FunctionCallVellumValue(
581
+ value=FunctionCall(
582
+ arguments={"key": "value"},
583
+ id="call_mcp_test",
584
+ name="test_tool",
585
+ state="FULFILLED",
586
+ ),
587
+ )
588
+ ],
589
+ },
590
+ )
591
+ )
592
+
593
+ mcp_node = mcp_node_class(state=state)
594
+
595
+ # AND mock MCPService to return a result
596
+ with mock.patch("vellum.workflows.nodes.displayable.tool_calling_node.utils.MCPService") as mock_mcp_service_class:
597
+ mock_mcp_service = mock.Mock()
598
+ mock_mcp_service.execute_tool.return_value = {"result": "mcp_test_result"}
599
+ mock_mcp_service_class.return_value = mock_mcp_service
600
+
601
+ # WHEN the MCP node runs
602
+ outputs = list(mcp_node.run())
603
+
604
+ # THEN there should be exactly one output with name "result"
605
+ assert len(outputs) == 1
606
+ result_output = outputs[0]
607
+ assert isinstance(result_output, BaseOutput)
608
+ assert result_output.name == "result"
609
+ assert result_output.is_fulfilled is True
610
+ assert result_output.value == {"result": "mcp_test_result"}
611
+
612
+
613
+ def test_vellum_integration_node_outputs_result(vellum_client):
614
+ """Test that VellumIntegrationNode yields output with name 'result' matching the Outputs class."""
615
+
616
+ # GIVEN a VellumIntegrationToolDefinition
617
+ github_tool = VellumIntegrationToolDefinition(
618
+ provider=VellumIntegrationProviderType.COMPOSIO,
619
+ integration_name="GITHUB",
620
+ name="create_issue",
621
+ description="Create a new issue in a GitHub repository",
622
+ )
623
+
624
+ # AND a tool prompt node
625
+ tool_prompt_node = create_tool_prompt_node(
626
+ ml_model="test-model",
627
+ blocks=[],
628
+ functions=[github_tool],
629
+ prompt_inputs=None,
630
+ parameters=DEFAULT_PROMPT_PARAMETERS,
631
+ )
632
+
633
+ function_node_class = create_function_node(
634
+ function=github_tool,
635
+ tool_prompt_node=tool_prompt_node,
636
+ )
637
+
638
+ # AND a state with a function call
639
+ state = ToolCallingState(
640
+ meta=StateMeta(
641
+ node_outputs={
642
+ tool_prompt_node.Outputs.results: [
643
+ FunctionCallVellumValue(
644
+ value=FunctionCall(
645
+ arguments={"owner": "test-owner", "repo": "test-repo", "title": "Test Issue"},
646
+ id="call_vellum_test",
647
+ name="create_issue",
648
+ state="FULFILLED",
649
+ ),
650
+ )
651
+ ],
652
+ },
653
+ )
654
+ )
655
+
656
+ # AND mock the vellum client's integration service
657
+ mock_response = mock.Mock()
658
+ mock_response.data = {"id": 123, "url": "https://github.com/test-owner/test-repo/issues/123"}
659
+ vellum_client.integrations.execute_integration_tool.return_value = mock_response
660
+
661
+ # AND create a context with the vellum client
662
+ context = WorkflowContext()
663
+ context.vellum_client = vellum_client
664
+
665
+ function_node = function_node_class(state=state)
666
+ function_node._context = context
667
+
668
+ # WHEN the VellumIntegration node runs
669
+ outputs = list(function_node.run())
670
+
671
+ # THEN there should be exactly one output with name "result"
672
+ assert len(outputs) == 1
673
+ result_output = outputs[0]
674
+ assert isinstance(result_output, BaseOutput)
675
+ assert result_output.name == "result"
676
+ assert result_output.is_fulfilled is True
677
+ assert result_output.value == {"id": 123, "url": "https://github.com/test-owner/test-repo/issues/123"}
678
+
679
+
680
+ def test_tool_calling_node_400_error_returns_internal_error(vellum_adhoc_prompt_client):
681
+ """
682
+ Test that ToolCallingNode returns INTERNAL_ERROR when the underlying prompt node returns a 400 error.
683
+ """
684
+
685
+ # GIVEN a ToolCallingNode with minimal configuration
686
+ class TestToolCallingNode(ToolCallingNode):
687
+ ml_model = "gpt-4o-mini"
688
+ blocks = []
689
+ functions = []
690
+ max_prompt_iterations = 1
691
+
692
+ # AND the API client raises a 400 error
693
+ api_error = ApiError(
694
+ status_code=400,
695
+ body={"detail": "Invalid request parameters"},
696
+ )
697
+ vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.side_effect = api_error
698
+
699
+ # AND a state
700
+ state = BaseState()
701
+
702
+ # WHEN the ToolCallingNode runs
703
+ node = TestToolCallingNode(state=state)
704
+
705
+ with pytest.raises(NodeException) as exc_info:
706
+ list(node.run())
707
+
708
+ # AND the error code should be INTERNAL_ERROR (not INVALID_INPUTS)
709
+ e = exc_info.value
710
+ assert e.code == WorkflowErrorCode.INTERNAL_ERROR
711
+ assert e.message == "Internal server error"
712
+
713
+
714
+ def test_vellum_integration_node_500_error_feeds_back_to_model(vellum_adhoc_prompt_client, vellum_client):
715
+ """
716
+ Test that NodeException errors from integration tools feed back an error response to the model.
717
+ """
718
+ # GIVEN a VellumIntegrationToolDefinition
719
+ github_create_issue_tool = VellumIntegrationToolDefinition(
720
+ provider=VellumIntegrationProviderType.COMPOSIO,
721
+ integration_name="GITHUB",
722
+ name="create_issue",
723
+ description="Create a new issue in a GitHub repository",
724
+ )
725
+
726
+ # AND a ToolCallingNode that uses the integration tool
727
+ class TestToolCallingNode(ToolCallingNode):
728
+ ml_model = "gpt-4o-mini"
729
+ blocks = []
730
+ functions = [github_create_issue_tool]
731
+ max_prompt_iterations = 2
732
+
733
+ # AND the integration API raises a 500 error
734
+ vellum_client.integrations.execute_integration_tool.side_effect = ApiError(
735
+ status_code=500,
736
+ body={"detail": "Internal server error occurred while executing the tool."},
737
+ )
738
+
739
+ def generate_prompt_events(*args: Any, **kwargs: Any) -> Iterator[Any]:
740
+ execution_id = str(uuid4())
741
+ call_count = vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.call_count
742
+
743
+ outputs: List[PromptOutput]
744
+ if call_count == 1:
745
+ outputs = [
746
+ FunctionCallVellumValue(
747
+ value=FunctionCall(
748
+ arguments={"owner": "test-owner", "repo": "test-repo", "title": "Test Issue"},
749
+ id="call_500_error_test",
750
+ name="create_issue",
751
+ state="FULFILLED",
752
+ ),
753
+ )
754
+ ]
755
+ else:
756
+ outputs = [
757
+ StringVellumValue(
758
+ value="I apologize, but I encountered an error while trying to create the issue. "
759
+ "The integration service is currently unavailable."
760
+ )
761
+ ]
762
+
763
+ events = [
764
+ InitiatedExecutePromptEvent(execution_id=execution_id),
765
+ FulfilledExecutePromptEvent(
766
+ execution_id=execution_id,
767
+ outputs=outputs,
768
+ ),
769
+ ]
770
+ yield from events
771
+
772
+ vellum_adhoc_prompt_client.adhoc_execute_prompt_stream.side_effect = generate_prompt_events
773
+
774
+ # WHEN the ToolCallingNode runs
775
+ state = ToolCallingState()
776
+ node = TestToolCallingNode(state=state)
777
+ node_outputs = {}
778
+ for output in node.run():
779
+ if output.is_fulfilled:
780
+ node_outputs[output.name] = output.value
781
+
782
+ # THEN the node should fulfill successfully
783
+ # AND the chat history should contain a FUNCTION message with the error
784
+ chat_history = cast(List[ChatMessage], node_outputs["chat_history"])
785
+ assert len(chat_history) == 3
786
+
787
+ # AND the first message should be the assistant's function call
788
+ assert chat_history[0].role == "ASSISTANT"
789
+
790
+ # AND the second message should be the FUNCTION error result
791
+ function_message = chat_history[1]
792
+ assert function_message.role == "FUNCTION"
793
+ assert isinstance(function_message.content, StringChatMessageContent)
794
+
795
+ # AND the error payload should contain the error details
796
+ error_data = json.loads(function_message.content.value)
797
+ assert "error" in error_data
798
+ assert error_data["error"]["code"] == "PROVIDER_ERROR"
799
+ assert "Internal server error occurred while executing the tool" in error_data["error"]["message"]
800
+
801
+ # AND the third message should be the assistant's response to the error
802
+ assert chat_history[2].role == "ASSISTANT"