flowent 0.0.7 → 0.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (386) hide show
  1. package/README.md +0 -3
  2. package/backend/README.md +0 -3
  3. package/backend/pyproject.toml +2 -8
  4. package/backend/src/flowent/__pycache__/__init__.cpython-313.pyc +0 -0
  5. package/backend/src/flowent/__pycache__/agent.cpython-313.pyc +0 -0
  6. package/backend/src/flowent/__pycache__/cli.cpython-313.pyc +0 -0
  7. package/backend/src/flowent/__pycache__/context.cpython-313.pyc +0 -0
  8. package/backend/src/flowent/__pycache__/llm.cpython-313.pyc +0 -0
  9. package/backend/src/flowent/__pycache__/logging.cpython-313.pyc +0 -0
  10. package/backend/src/flowent/__pycache__/main.cpython-313.pyc +0 -0
  11. package/backend/src/flowent/__pycache__/patch.cpython-313.pyc +0 -0
  12. package/backend/src/flowent/__pycache__/paths.cpython-313.pyc +0 -0
  13. package/backend/src/flowent/__pycache__/sandbox.cpython-313.pyc +0 -0
  14. package/backend/src/flowent/__pycache__/storage.cpython-313.pyc +0 -0
  15. package/backend/src/flowent/__pycache__/tools.cpython-313.pyc +0 -0
  16. package/backend/src/flowent/agent.py +213 -3173
  17. package/backend/src/flowent/cli.py +19 -24
  18. package/backend/src/flowent/context.py +127 -0
  19. package/backend/src/flowent/llm.py +256 -0
  20. package/backend/src/flowent/logging.py +170 -129
  21. package/backend/src/flowent/main.py +321 -70
  22. package/backend/src/flowent/patch.py +182 -0
  23. package/backend/src/flowent/paths.py +11 -0
  24. package/backend/src/flowent/sandbox.py +214 -40
  25. package/backend/src/flowent/static/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2 +0 -0
  26. package/backend/src/flowent/static/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2 +0 -0
  27. package/backend/src/flowent/static/assets/geist-latin-wght-normal-Dm3htQBi.woff2 +0 -0
  28. package/backend/src/flowent/static/assets/index-C76K95ty.js +81 -0
  29. package/backend/src/flowent/static/assets/index-iUMNKvlU.css +2 -0
  30. package/backend/src/flowent/static/flowent.png +0 -0
  31. package/backend/src/flowent/static/index.html +5 -25
  32. package/backend/src/flowent/storage.py +302 -0
  33. package/backend/src/flowent/tools.py +364 -0
  34. package/backend/tests/__pycache__/test_agent_tools.cpython-313-pytest-9.0.3.pyc +0 -0
  35. package/backend/tests/__pycache__/test_health.cpython-313-pytest-9.0.3.pyc +0 -0
  36. package/backend/tests/__pycache__/test_llm_providers.cpython-313-pytest-9.0.3.pyc +0 -0
  37. package/backend/tests/__pycache__/test_logging.cpython-313-pytest-9.0.3.pyc +0 -0
  38. package/backend/tests/__pycache__/test_persistence.cpython-313-pytest-9.0.3.pyc +0 -0
  39. package/backend/tests/__pycache__/test_workspace_chat.cpython-313-pytest-9.0.3.pyc +0 -0
  40. package/backend/tests/test_agent_tools.py +449 -0
  41. package/backend/tests/test_health.py +12 -0
  42. package/backend/tests/test_llm_providers.py +113 -0
  43. package/backend/tests/test_logging.py +182 -0
  44. package/backend/tests/test_persistence.py +125 -0
  45. package/backend/tests/test_workspace_chat.py +578 -0
  46. package/backend/uv.lock +803 -99
  47. package/dist/frontend/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2 +0 -0
  48. package/dist/frontend/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2 +0 -0
  49. package/dist/frontend/assets/geist-latin-wght-normal-Dm3htQBi.woff2 +0 -0
  50. package/dist/frontend/assets/index-C76K95ty.js +81 -0
  51. package/dist/frontend/assets/index-iUMNKvlU.css +2 -0
  52. package/dist/frontend/flowent.png +0 -0
  53. package/dist/frontend/index.html +5 -25
  54. package/package.json +1 -2
  55. package/backend/src/flowent/__pycache__/_version.cpython-313.pyc +0 -0
  56. package/backend/src/flowent/__pycache__/access.cpython-313.pyc +0 -0
  57. package/backend/src/flowent/__pycache__/assistant_commands.cpython-313.pyc +0 -0
  58. package/backend/src/flowent/__pycache__/config.cpython-313.pyc +0 -0
  59. package/backend/src/flowent/__pycache__/events.cpython-313.pyc +0 -0
  60. package/backend/src/flowent/__pycache__/graph_runtime.cpython-313.pyc +0 -0
  61. package/backend/src/flowent/__pycache__/graph_service.cpython-313.pyc +0 -0
  62. package/backend/src/flowent/__pycache__/image_assets.cpython-313.pyc +0 -0
  63. package/backend/src/flowent/__pycache__/model_metadata.cpython-313.pyc +0 -0
  64. package/backend/src/flowent/__pycache__/network.cpython-313.pyc +0 -0
  65. package/backend/src/flowent/__pycache__/observability_service.cpython-313.pyc +0 -0
  66. package/backend/src/flowent/__pycache__/registry.cpython-313.pyc +0 -0
  67. package/backend/src/flowent/__pycache__/role_management.cpython-313.pyc +0 -0
  68. package/backend/src/flowent/__pycache__/runtime.cpython-313.pyc +0 -0
  69. package/backend/src/flowent/__pycache__/security.cpython-313.pyc +0 -0
  70. package/backend/src/flowent/__pycache__/settings.cpython-313.pyc +0 -0
  71. package/backend/src/flowent/__pycache__/settings_management.cpython-313.pyc +0 -0
  72. package/backend/src/flowent/__pycache__/state_db.cpython-313.pyc +0 -0
  73. package/backend/src/flowent/__pycache__/workspace_store.cpython-313.pyc +0 -0
  74. package/backend/src/flowent/access.py +0 -247
  75. package/backend/src/flowent/assistant_commands.py +0 -115
  76. package/backend/src/flowent/channels/__init__.py +0 -3
  77. package/backend/src/flowent/channels/__pycache__/__init__.cpython-313.pyc +0 -0
  78. package/backend/src/flowent/channels/__pycache__/telegram.cpython-313.pyc +0 -0
  79. package/backend/src/flowent/channels/telegram.py +0 -615
  80. package/backend/src/flowent/config.py +0 -14
  81. package/backend/src/flowent/dev.py +0 -3
  82. package/backend/src/flowent/events.py +0 -157
  83. package/backend/src/flowent/graph_runtime.py +0 -60
  84. package/backend/src/flowent/graph_service.py +0 -2401
  85. package/backend/src/flowent/image_assets.py +0 -356
  86. package/backend/src/flowent/model_metadata.py +0 -102
  87. package/backend/src/flowent/models/__init__.py +0 -125
  88. package/backend/src/flowent/models/__pycache__/__init__.cpython-313.pyc +0 -0
  89. package/backend/src/flowent/models/__pycache__/agent.cpython-313.pyc +0 -0
  90. package/backend/src/flowent/models/__pycache__/base.cpython-313.pyc +0 -0
  91. package/backend/src/flowent/models/__pycache__/blueprint.cpython-313.pyc +0 -0
  92. package/backend/src/flowent/models/__pycache__/content.cpython-313.pyc +0 -0
  93. package/backend/src/flowent/models/__pycache__/delta.cpython-313.pyc +0 -0
  94. package/backend/src/flowent/models/__pycache__/event.cpython-313.pyc +0 -0
  95. package/backend/src/flowent/models/__pycache__/graph.cpython-313.pyc +0 -0
  96. package/backend/src/flowent/models/__pycache__/history.cpython-313.pyc +0 -0
  97. package/backend/src/flowent/models/__pycache__/llm.cpython-313.pyc +0 -0
  98. package/backend/src/flowent/models/__pycache__/message.cpython-313.pyc +0 -0
  99. package/backend/src/flowent/models/__pycache__/tab.cpython-313.pyc +0 -0
  100. package/backend/src/flowent/models/__pycache__/todo.cpython-313.pyc +0 -0
  101. package/backend/src/flowent/models/agent.py +0 -34
  102. package/backend/src/flowent/models/base.py +0 -24
  103. package/backend/src/flowent/models/blueprint.py +0 -176
  104. package/backend/src/flowent/models/content.py +0 -164
  105. package/backend/src/flowent/models/delta.py +0 -44
  106. package/backend/src/flowent/models/event.py +0 -51
  107. package/backend/src/flowent/models/graph.py +0 -472
  108. package/backend/src/flowent/models/history.py +0 -272
  109. package/backend/src/flowent/models/llm.py +0 -62
  110. package/backend/src/flowent/models/message.py +0 -33
  111. package/backend/src/flowent/models/tab.py +0 -85
  112. package/backend/src/flowent/models/todo.py +0 -10
  113. package/backend/src/flowent/network.py +0 -146
  114. package/backend/src/flowent/observability_service.py +0 -218
  115. package/backend/src/flowent/prompts/__init__.py +0 -67
  116. package/backend/src/flowent/prompts/__pycache__/__init__.cpython-313.pyc +0 -0
  117. package/backend/src/flowent/prompts/__pycache__/common.cpython-313.pyc +0 -0
  118. package/backend/src/flowent/prompts/__pycache__/steward.cpython-313.pyc +0 -0
  119. package/backend/src/flowent/prompts/common.py +0 -250
  120. package/backend/src/flowent/prompts/steward.py +0 -64
  121. package/backend/src/flowent/providers/__init__.py +0 -23
  122. package/backend/src/flowent/providers/__pycache__/__init__.cpython-313.pyc +0 -0
  123. package/backend/src/flowent/providers/__pycache__/anthropic.cpython-313.pyc +0 -0
  124. package/backend/src/flowent/providers/__pycache__/base_url.cpython-313.pyc +0 -0
  125. package/backend/src/flowent/providers/__pycache__/configuration.cpython-313.pyc +0 -0
  126. package/backend/src/flowent/providers/__pycache__/content.cpython-313.pyc +0 -0
  127. package/backend/src/flowent/providers/__pycache__/errors.cpython-313.pyc +0 -0
  128. package/backend/src/flowent/providers/__pycache__/gateway.cpython-313.pyc +0 -0
  129. package/backend/src/flowent/providers/__pycache__/headers.cpython-313.pyc +0 -0
  130. package/backend/src/flowent/providers/__pycache__/management.cpython-313.pyc +0 -0
  131. package/backend/src/flowent/providers/__pycache__/openai.cpython-313.pyc +0 -0
  132. package/backend/src/flowent/providers/__pycache__/openai_responses.cpython-313.pyc +0 -0
  133. package/backend/src/flowent/providers/__pycache__/registry.cpython-313.pyc +0 -0
  134. package/backend/src/flowent/providers/__pycache__/sse.cpython-313.pyc +0 -0
  135. package/backend/src/flowent/providers/__pycache__/thinking.cpython-313.pyc +0 -0
  136. package/backend/src/flowent/providers/anthropic.py +0 -468
  137. package/backend/src/flowent/providers/base_url.py +0 -60
  138. package/backend/src/flowent/providers/configuration.py +0 -189
  139. package/backend/src/flowent/providers/content.py +0 -122
  140. package/backend/src/flowent/providers/errors.py +0 -223
  141. package/backend/src/flowent/providers/gateway.py +0 -169
  142. package/backend/src/flowent/providers/gemini.py +0 -447
  143. package/backend/src/flowent/providers/headers.py +0 -20
  144. package/backend/src/flowent/providers/management.py +0 -96
  145. package/backend/src/flowent/providers/ollama.py +0 -293
  146. package/backend/src/flowent/providers/openai.py +0 -422
  147. package/backend/src/flowent/providers/openai_responses.py +0 -655
  148. package/backend/src/flowent/providers/registry.py +0 -144
  149. package/backend/src/flowent/providers/sse.py +0 -31
  150. package/backend/src/flowent/providers/thinking.py +0 -79
  151. package/backend/src/flowent/registry.py +0 -73
  152. package/backend/src/flowent/role_management.py +0 -270
  153. package/backend/src/flowent/routes/__init__.py +0 -26
  154. package/backend/src/flowent/routes/__pycache__/__init__.cpython-313.pyc +0 -0
  155. package/backend/src/flowent/routes/__pycache__/access.cpython-313.pyc +0 -0
  156. package/backend/src/flowent/routes/__pycache__/assistant.cpython-313.pyc +0 -0
  157. package/backend/src/flowent/routes/__pycache__/image_assets.cpython-313.pyc +0 -0
  158. package/backend/src/flowent/routes/__pycache__/meta.cpython-313.pyc +0 -0
  159. package/backend/src/flowent/routes/__pycache__/nodes.cpython-313.pyc +0 -0
  160. package/backend/src/flowent/routes/__pycache__/prompts.cpython-313.pyc +0 -0
  161. package/backend/src/flowent/routes/__pycache__/providers_route.cpython-313.pyc +0 -0
  162. package/backend/src/flowent/routes/__pycache__/roles.cpython-313.pyc +0 -0
  163. package/backend/src/flowent/routes/__pycache__/settings.cpython-313.pyc +0 -0
  164. package/backend/src/flowent/routes/__pycache__/tabs.cpython-313.pyc +0 -0
  165. package/backend/src/flowent/routes/__pycache__/ws.cpython-313.pyc +0 -0
  166. package/backend/src/flowent/routes/access.py +0 -48
  167. package/backend/src/flowent/routes/assistant.py +0 -158
  168. package/backend/src/flowent/routes/image_assets.py +0 -33
  169. package/backend/src/flowent/routes/meta.py +0 -28
  170. package/backend/src/flowent/routes/nodes.py +0 -423
  171. package/backend/src/flowent/routes/prompts.py +0 -46
  172. package/backend/src/flowent/routes/providers_route.py +0 -365
  173. package/backend/src/flowent/routes/roles.py +0 -207
  174. package/backend/src/flowent/routes/settings.py +0 -379
  175. package/backend/src/flowent/routes/tabs.py +0 -298
  176. package/backend/src/flowent/routes/ws.py +0 -33
  177. package/backend/src/flowent/runtime.py +0 -160
  178. package/backend/src/flowent/security.py +0 -37
  179. package/backend/src/flowent/settings.py +0 -2112
  180. package/backend/src/flowent/settings_management.py +0 -394
  181. package/backend/src/flowent/state_db.py +0 -108
  182. package/backend/src/flowent/static/assets/AssistantPage-BW7XAd9I.js +0 -1
  183. package/backend/src/flowent/static/assets/ChannelsPage-tCJHgt6m.js +0 -1
  184. package/backend/src/flowent/static/assets/PageScaffold-f6g2l7XN.js +0 -1
  185. package/backend/src/flowent/static/assets/PromptsPage-C3Sxn2D7.js +0 -1
  186. package/backend/src/flowent/static/assets/ProvidersPage-BfmdXmNt.js +0 -3
  187. package/backend/src/flowent/static/assets/RolesPage-DET8wO4r.js +0 -1
  188. package/backend/src/flowent/static/assets/SettingsPage-D-g3deMm.js +0 -3
  189. package/backend/src/flowent/static/assets/ToolsPage-CDmtE2g4.js +0 -1
  190. package/backend/src/flowent/static/assets/WorkspacePage-AZsJ0sD0.js +0 -3
  191. package/backend/src/flowent/static/assets/WorkspacePanels-CteCjolX.js +0 -1
  192. package/backend/src/flowent/static/assets/alert-dialog-Duorp_S-.js +0 -1
  193. package/backend/src/flowent/static/assets/dialog-C3ixjGjN.js +0 -1
  194. package/backend/src/flowent/static/assets/elk-worker.min-C9JGDOE-.js +0 -6312
  195. package/backend/src/flowent/static/assets/graph-vendor-CHpVij2M.css +0 -1
  196. package/backend/src/flowent/static/assets/graph-vendor-DRq_-6fV.js +0 -7
  197. package/backend/src/flowent/static/assets/index--o_0fv0N.css +0 -1
  198. package/backend/src/flowent/static/assets/index-C9HuekJm.js +0 -10
  199. package/backend/src/flowent/static/assets/layout.worker-jMHqAFbP.js +0 -24
  200. package/backend/src/flowent/static/assets/markdown-vendor-C9RtvaJh.js +0 -29
  201. package/backend/src/flowent/static/assets/modelParams-DmnF2hwR.js +0 -1
  202. package/backend/src/flowent/static/assets/providerTypes-DT3Ahwl_.js +0 -1
  203. package/backend/src/flowent/static/assets/react-vendor-mEs_JJxa.js +0 -9
  204. package/backend/src/flowent/static/assets/roles-CuRT_chR.js +0 -1
  205. package/backend/src/flowent/static/assets/rolldown-runtime-BYbx6iT9.js +0 -1
  206. package/backend/src/flowent/static/assets/select-DCfeNu-F.js +0 -1
  207. package/backend/src/flowent/static/assets/surface-pWwG5ogx.js +0 -1
  208. package/backend/src/flowent/static/assets/ui-vendor-C5pJa8N7.js +0 -51
  209. package/backend/src/flowent/static/assets/useAppRoute-FgSHBKhV.js +0 -1
  210. package/backend/src/flowent/static/favicon.svg +0 -4
  211. package/backend/src/flowent/tools/__init__.py +0 -176
  212. package/backend/src/flowent/tools/__pycache__/__init__.cpython-313.pyc +0 -0
  213. package/backend/src/flowent/tools/__pycache__/connect.cpython-313.pyc +0 -0
  214. package/backend/src/flowent/tools/__pycache__/contacts.cpython-313.pyc +0 -0
  215. package/backend/src/flowent/tools/__pycache__/create_agent.cpython-313.pyc +0 -0
  216. package/backend/src/flowent/tools/__pycache__/create_tab.cpython-313.pyc +0 -0
  217. package/backend/src/flowent/tools/__pycache__/delete_tab.cpython-313.pyc +0 -0
  218. package/backend/src/flowent/tools/__pycache__/edit.cpython-313.pyc +0 -0
  219. package/backend/src/flowent/tools/__pycache__/exec.cpython-313.pyc +0 -0
  220. package/backend/src/flowent/tools/__pycache__/fetch.cpython-313.pyc +0 -0
  221. package/backend/src/flowent/tools/__pycache__/idle.cpython-313.pyc +0 -0
  222. package/backend/src/flowent/tools/__pycache__/list_roles.cpython-313.pyc +0 -0
  223. package/backend/src/flowent/tools/__pycache__/list_tabs.cpython-313.pyc +0 -0
  224. package/backend/src/flowent/tools/__pycache__/list_tools.cpython-313.pyc +0 -0
  225. package/backend/src/flowent/tools/__pycache__/manage_prompts.cpython-313.pyc +0 -0
  226. package/backend/src/flowent/tools/__pycache__/manage_providers.cpython-313.pyc +0 -0
  227. package/backend/src/flowent/tools/__pycache__/manage_roles.cpython-313.pyc +0 -0
  228. package/backend/src/flowent/tools/__pycache__/manage_settings.cpython-313.pyc +0 -0
  229. package/backend/src/flowent/tools/__pycache__/read.cpython-313.pyc +0 -0
  230. package/backend/src/flowent/tools/__pycache__/send.cpython-313.pyc +0 -0
  231. package/backend/src/flowent/tools/__pycache__/set_permissions.cpython-313.pyc +0 -0
  232. package/backend/src/flowent/tools/__pycache__/sleep.cpython-313.pyc +0 -0
  233. package/backend/src/flowent/tools/__pycache__/todo.cpython-313.pyc +0 -0
  234. package/backend/src/flowent/tools/connect.py +0 -100
  235. package/backend/src/flowent/tools/contacts.py +0 -22
  236. package/backend/src/flowent/tools/create_agent.py +0 -191
  237. package/backend/src/flowent/tools/create_tab.py +0 -61
  238. package/backend/src/flowent/tools/delete_tab.py +0 -39
  239. package/backend/src/flowent/tools/edit.py +0 -142
  240. package/backend/src/flowent/tools/exec.py +0 -118
  241. package/backend/src/flowent/tools/fetch.py +0 -85
  242. package/backend/src/flowent/tools/idle.py +0 -27
  243. package/backend/src/flowent/tools/list_roles.py +0 -68
  244. package/backend/src/flowent/tools/list_tabs.py +0 -100
  245. package/backend/src/flowent/tools/list_tools.py +0 -28
  246. package/backend/src/flowent/tools/manage_prompts.py +0 -102
  247. package/backend/src/flowent/tools/manage_providers.py +0 -220
  248. package/backend/src/flowent/tools/manage_roles.py +0 -275
  249. package/backend/src/flowent/tools/manage_settings.py +0 -326
  250. package/backend/src/flowent/tools/read.py +0 -152
  251. package/backend/src/flowent/tools/send.py +0 -68
  252. package/backend/src/flowent/tools/set_permissions.py +0 -99
  253. package/backend/src/flowent/tools/sleep.py +0 -41
  254. package/backend/src/flowent/tools/todo.py +0 -51
  255. package/backend/src/flowent/workspace_store.py +0 -479
  256. package/backend/tests/__init__.py +0 -0
  257. package/backend/tests/__pycache__/__init__.cpython-313.pyc +0 -0
  258. package/backend/tests/__pycache__/conftest.cpython-313-pytest-9.0.3.pyc +0 -0
  259. package/backend/tests/conftest.py +0 -6
  260. package/backend/tests/integration/api/__pycache__/conftest.cpython-313-pytest-9.0.3.pyc +0 -0
  261. package/backend/tests/integration/api/__pycache__/test_access_api.cpython-313-pytest-9.0.3.pyc +0 -0
  262. package/backend/tests/integration/api/__pycache__/test_assistant_api.cpython-313-pytest-9.0.3.pyc +0 -0
  263. package/backend/tests/integration/api/__pycache__/test_frontend_mounting.cpython-313-pytest-9.0.3.pyc +0 -0
  264. package/backend/tests/integration/api/__pycache__/test_meta_api.cpython-313-pytest-9.0.3.pyc +0 -0
  265. package/backend/tests/integration/api/__pycache__/test_nodes_api.cpython-313-pytest-9.0.3.pyc +0 -0
  266. package/backend/tests/integration/api/__pycache__/test_prompts_api.cpython-313-pytest-9.0.3.pyc +0 -0
  267. package/backend/tests/integration/api/__pycache__/test_roles_api.cpython-313-pytest-9.0.3.pyc +0 -0
  268. package/backend/tests/integration/api/__pycache__/test_tabs_api.cpython-313-pytest-9.0.3.pyc +0 -0
  269. package/backend/tests/integration/api/conftest.py +0 -29
  270. package/backend/tests/integration/api/test_access_api.py +0 -182
  271. package/backend/tests/integration/api/test_assistant_api.py +0 -422
  272. package/backend/tests/integration/api/test_frontend_mounting.py +0 -61
  273. package/backend/tests/integration/api/test_meta_api.py +0 -32
  274. package/backend/tests/integration/api/test_nodes_api.py +0 -787
  275. package/backend/tests/integration/api/test_prompts_api.py +0 -47
  276. package/backend/tests/integration/api/test_roles_api.py +0 -228
  277. package/backend/tests/integration/api/test_tabs_api.py +0 -688
  278. package/backend/tests/unit/__pycache__/test_access.cpython-313-pytest-9.0.3.pyc +0 -0
  279. package/backend/tests/unit/__pycache__/test_cli.cpython-313-pytest-9.0.3.pyc +0 -0
  280. package/backend/tests/unit/__pycache__/test_graph_runtime.cpython-313-pytest-9.0.3.pyc +0 -0
  281. package/backend/tests/unit/__pycache__/test_network.cpython-313-pytest-9.0.3.pyc +0 -0
  282. package/backend/tests/unit/__pycache__/test_state_sqlite_storage.cpython-313-pytest-9.0.3.pyc +0 -0
  283. package/backend/tests/unit/__pycache__/test_workspace_store.cpython-313-pytest-9.0.3.pyc +0 -0
  284. package/backend/tests/unit/agent/__pycache__/test_agent_public_api.cpython-313-pytest-9.0.3.pyc +0 -0
  285. package/backend/tests/unit/agent/__pycache__/test_agent_runtime.cpython-313-pytest-9.0.3.pyc +0 -0
  286. package/backend/tests/unit/agent/test_agent_public_api.py +0 -822
  287. package/backend/tests/unit/agent/test_agent_runtime.py +0 -3088
  288. package/backend/tests/unit/channels/__pycache__/test_telegram_channel.cpython-313-pytest-9.0.3.pyc +0 -0
  289. package/backend/tests/unit/channels/test_telegram_channel.py +0 -552
  290. package/backend/tests/unit/logging/__pycache__/test_logging.cpython-313-pytest-9.0.3.pyc +0 -0
  291. package/backend/tests/unit/logging/test_logging.py +0 -132
  292. package/backend/tests/unit/prompts/__pycache__/test_prompts.cpython-313-pytest-9.0.3.pyc +0 -0
  293. package/backend/tests/unit/prompts/test_prompts.py +0 -570
  294. package/backend/tests/unit/providers/__pycache__/test_anthropic_provider.cpython-313-pytest-9.0.3.pyc +0 -0
  295. package/backend/tests/unit/providers/__pycache__/test_errors.cpython-313-pytest-9.0.3.pyc +0 -0
  296. package/backend/tests/unit/providers/__pycache__/test_extract_delta_parts.cpython-313-pytest-9.0.3.pyc +0 -0
  297. package/backend/tests/unit/providers/__pycache__/test_openai_provider.cpython-313-pytest-9.0.3.pyc +0 -0
  298. package/backend/tests/unit/providers/__pycache__/test_openai_responses.cpython-313-pytest-9.0.3.pyc +0 -0
  299. package/backend/tests/unit/providers/__pycache__/test_provider_gateway.cpython-313-pytest-9.0.3.pyc +0 -0
  300. package/backend/tests/unit/providers/__pycache__/test_think_tag_parser.cpython-313-pytest-9.0.3.pyc +0 -0
  301. package/backend/tests/unit/providers/test_anthropic_provider.py +0 -185
  302. package/backend/tests/unit/providers/test_errors.py +0 -68
  303. package/backend/tests/unit/providers/test_extract_delta_parts.py +0 -22
  304. package/backend/tests/unit/providers/test_openai_provider.py +0 -139
  305. package/backend/tests/unit/providers/test_openai_responses.py +0 -402
  306. package/backend/tests/unit/providers/test_provider_gateway.py +0 -359
  307. package/backend/tests/unit/providers/test_think_tag_parser.py +0 -36
  308. package/backend/tests/unit/routes/__pycache__/test_prompts_routes.cpython-313-pytest-9.0.3.pyc +0 -0
  309. package/backend/tests/unit/routes/__pycache__/test_providers_route.cpython-313-pytest-9.0.3.pyc +0 -0
  310. package/backend/tests/unit/routes/__pycache__/test_roles_routes.cpython-313-pytest-9.0.3.pyc +0 -0
  311. package/backend/tests/unit/routes/__pycache__/test_settings_routes.cpython-313-pytest-9.0.3.pyc +0 -0
  312. package/backend/tests/unit/routes/test_prompts_routes.py +0 -82
  313. package/backend/tests/unit/routes/test_providers_route.py +0 -370
  314. package/backend/tests/unit/routes/test_roles_routes.py +0 -539
  315. package/backend/tests/unit/routes/test_settings_routes.py +0 -1123
  316. package/backend/tests/unit/runtime/__pycache__/test_bootstrap_runtime.cpython-313-pytest-9.0.3.pyc +0 -0
  317. package/backend/tests/unit/runtime/test_bootstrap_runtime.py +0 -1002
  318. package/backend/tests/unit/sandbox/__pycache__/test_sandbox_tools.cpython-313-pytest-9.0.3.pyc +0 -0
  319. package/backend/tests/unit/sandbox/test_sandbox_tools.py +0 -78
  320. package/backend/tests/unit/security/__pycache__/test_security.cpython-313-pytest-9.0.3.pyc +0 -0
  321. package/backend/tests/unit/security/test_security.py +0 -124
  322. package/backend/tests/unit/settings/__pycache__/test_settings_roles.cpython-313-pytest-9.0.3.pyc +0 -0
  323. package/backend/tests/unit/settings/test_settings_roles.py +0 -703
  324. package/backend/tests/unit/test_access.py +0 -45
  325. package/backend/tests/unit/test_cli.py +0 -102
  326. package/backend/tests/unit/test_graph_runtime.py +0 -72
  327. package/backend/tests/unit/test_network.py +0 -51
  328. package/backend/tests/unit/test_state_sqlite_storage.py +0 -87
  329. package/backend/tests/unit/test_workspace_store.py +0 -228
  330. package/backend/tests/unit/tools/__pycache__/test_connect_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  331. package/backend/tests/unit/tools/__pycache__/test_create_agent_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  332. package/backend/tests/unit/tools/__pycache__/test_delete_tab_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  333. package/backend/tests/unit/tools/__pycache__/test_edit_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  334. package/backend/tests/unit/tools/__pycache__/test_exec_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  335. package/backend/tests/unit/tools/__pycache__/test_fetch_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  336. package/backend/tests/unit/tools/__pycache__/test_manage_prompts_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  337. package/backend/tests/unit/tools/__pycache__/test_manage_providers_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  338. package/backend/tests/unit/tools/__pycache__/test_manage_roles_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  339. package/backend/tests/unit/tools/__pycache__/test_manage_settings_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  340. package/backend/tests/unit/tools/__pycache__/test_read_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  341. package/backend/tests/unit/tools/__pycache__/test_set_permissions_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  342. package/backend/tests/unit/tools/__pycache__/test_todo_tool.cpython-313-pytest-9.0.3.pyc +0 -0
  343. package/backend/tests/unit/tools/__pycache__/test_tool_registry.cpython-313-pytest-9.0.3.pyc +0 -0
  344. package/backend/tests/unit/tools/test_connect_tool.py +0 -228
  345. package/backend/tests/unit/tools/test_create_agent_tool.py +0 -404
  346. package/backend/tests/unit/tools/test_delete_tab_tool.py +0 -116
  347. package/backend/tests/unit/tools/test_edit_tool.py +0 -115
  348. package/backend/tests/unit/tools/test_exec_tool.py +0 -81
  349. package/backend/tests/unit/tools/test_fetch_tool.py +0 -65
  350. package/backend/tests/unit/tools/test_manage_prompts_tool.py +0 -92
  351. package/backend/tests/unit/tools/test_manage_providers_tool.py +0 -460
  352. package/backend/tests/unit/tools/test_manage_roles_tool.py +0 -411
  353. package/backend/tests/unit/tools/test_manage_settings_tool.py +0 -611
  354. package/backend/tests/unit/tools/test_read_tool.py +0 -33
  355. package/backend/tests/unit/tools/test_set_permissions_tool.py +0 -595
  356. package/backend/tests/unit/tools/test_todo_tool.py +0 -37
  357. package/backend/tests/unit/tools/test_tool_registry.py +0 -199
  358. package/dist/frontend/assets/AssistantPage-BW7XAd9I.js +0 -1
  359. package/dist/frontend/assets/ChannelsPage-tCJHgt6m.js +0 -1
  360. package/dist/frontend/assets/PageScaffold-f6g2l7XN.js +0 -1
  361. package/dist/frontend/assets/PromptsPage-C3Sxn2D7.js +0 -1
  362. package/dist/frontend/assets/ProvidersPage-BfmdXmNt.js +0 -3
  363. package/dist/frontend/assets/RolesPage-DET8wO4r.js +0 -1
  364. package/dist/frontend/assets/SettingsPage-D-g3deMm.js +0 -3
  365. package/dist/frontend/assets/ToolsPage-CDmtE2g4.js +0 -1
  366. package/dist/frontend/assets/WorkspacePage-AZsJ0sD0.js +0 -3
  367. package/dist/frontend/assets/WorkspacePanels-CteCjolX.js +0 -1
  368. package/dist/frontend/assets/alert-dialog-Duorp_S-.js +0 -1
  369. package/dist/frontend/assets/dialog-C3ixjGjN.js +0 -1
  370. package/dist/frontend/assets/elk-worker.min-C9JGDOE-.js +0 -6312
  371. package/dist/frontend/assets/graph-vendor-CHpVij2M.css +0 -1
  372. package/dist/frontend/assets/graph-vendor-DRq_-6fV.js +0 -7
  373. package/dist/frontend/assets/index--o_0fv0N.css +0 -1
  374. package/dist/frontend/assets/index-C9HuekJm.js +0 -10
  375. package/dist/frontend/assets/layout.worker-jMHqAFbP.js +0 -24
  376. package/dist/frontend/assets/markdown-vendor-C9RtvaJh.js +0 -29
  377. package/dist/frontend/assets/modelParams-DmnF2hwR.js +0 -1
  378. package/dist/frontend/assets/providerTypes-DT3Ahwl_.js +0 -1
  379. package/dist/frontend/assets/react-vendor-mEs_JJxa.js +0 -9
  380. package/dist/frontend/assets/roles-CuRT_chR.js +0 -1
  381. package/dist/frontend/assets/rolldown-runtime-BYbx6iT9.js +0 -1
  382. package/dist/frontend/assets/select-DCfeNu-F.js +0 -1
  383. package/dist/frontend/assets/surface-pWwG5ogx.js +0 -1
  384. package/dist/frontend/assets/ui-vendor-C5pJa8N7.js +0 -51
  385. package/dist/frontend/assets/useAppRoute-FgSHBKhV.js +0 -1
  386. package/dist/frontend/favicon.svg +0 -4
@@ -1,539 +0,0 @@
1
- import asyncio
2
-
3
- import pytest
4
- from fastapi import HTTPException
5
-
6
- from flowent.routes.roles import (
7
- CreateRoleRequest,
8
- RoleModelRequest,
9
- UpdateRoleRequest,
10
- create_role,
11
- delete_role,
12
- list_roles,
13
- update_role,
14
- )
15
- from flowent.settings import (
16
- CONDUCTOR_ROLE_NAME,
17
- DESIGNER_ROLE_NAME,
18
- STEWARD_ROLE_INCLUDED_TOOLS,
19
- STEWARD_ROLE_NAME,
20
- AssistantSettings,
21
- ProviderConfig,
22
- ProviderModelCatalogEntry,
23
- RoleConfig,
24
- RoleModelConfig,
25
- Settings,
26
- )
27
-
28
-
29
- def test_list_roles_returns_is_builtin_flags(monkeypatch):
30
- settings = Settings(
31
- roles=[
32
- RoleConfig(
33
- name="Worker",
34
- description="General execution role",
35
- system_prompt="Do work.",
36
- included_tools=["read", "exec"],
37
- ),
38
- RoleConfig(
39
- name=CONDUCTOR_ROLE_NAME,
40
- description="Leader role",
41
- system_prompt="Coordinate tasks.",
42
- included_tools=[
43
- "create_agent",
44
- "connect",
45
- "list_roles",
46
- "list_tools",
47
- ],
48
- ),
49
- RoleConfig(
50
- name=DESIGNER_ROLE_NAME,
51
- description="Frontend design role",
52
- system_prompt="Design interfaces.",
53
- included_tools=["read", "edit", "exec"],
54
- ),
55
- RoleConfig(
56
- name="Reviewer",
57
- description="Review code carefully",
58
- system_prompt="Review code carefully",
59
- included_tools=["read"],
60
- excluded_tools=["fetch"],
61
- ),
62
- ]
63
- )
64
-
65
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
66
-
67
- result = asyncio.run(list_roles())
68
-
69
- assert result == {
70
- "roles": [
71
- {
72
- "name": "Worker",
73
- "description": "General execution role",
74
- "system_prompt": "Do work.",
75
- "model": None,
76
- "model_params": None,
77
- "included_tools": ["read", "exec"],
78
- "excluded_tools": [],
79
- "is_builtin": True,
80
- },
81
- {
82
- "name": CONDUCTOR_ROLE_NAME,
83
- "description": "Leader role",
84
- "system_prompt": "Coordinate tasks.",
85
- "model": None,
86
- "model_params": None,
87
- "included_tools": [
88
- "create_agent",
89
- "connect",
90
- "list_roles",
91
- "list_tools",
92
- ],
93
- "excluded_tools": [],
94
- "is_builtin": True,
95
- },
96
- {
97
- "name": DESIGNER_ROLE_NAME,
98
- "description": "Frontend design role",
99
- "system_prompt": "Design interfaces.",
100
- "model": None,
101
- "model_params": None,
102
- "included_tools": ["read", "edit", "exec"],
103
- "excluded_tools": [],
104
- "is_builtin": True,
105
- },
106
- {
107
- "name": "Reviewer",
108
- "description": "Review code carefully",
109
- "system_prompt": "Review code carefully",
110
- "model": None,
111
- "model_params": None,
112
- "included_tools": ["read"],
113
- "excluded_tools": ["fetch"],
114
- "is_builtin": False,
115
- },
116
- ]
117
- }
118
-
119
-
120
- def test_create_role_uses_name_as_identifier(monkeypatch):
121
- settings = Settings()
122
- saved: list[list[str]] = []
123
-
124
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
125
- monkeypatch.setattr(
126
- "flowent.routes.roles.save_settings",
127
- lambda current: saved.append([role.name for role in current.roles]),
128
- )
129
-
130
- result = asyncio.run(
131
- create_role(
132
- CreateRoleRequest(
133
- name="Reviewer",
134
- description="Review code carefully",
135
- system_prompt="Review code carefully",
136
- included_tools=["read"],
137
- )
138
- )
139
- )
140
-
141
- assert result == {
142
- "name": "Reviewer",
143
- "description": "Review code carefully",
144
- "system_prompt": "Review code carefully",
145
- "model": None,
146
- "model_params": None,
147
- "included_tools": ["read"],
148
- "excluded_tools": [],
149
- "is_builtin": False,
150
- }
151
- assert settings.roles == [
152
- RoleConfig(
153
- name="Reviewer",
154
- description="Review code carefully",
155
- system_prompt="Review code carefully",
156
- included_tools=["read"],
157
- )
158
- ]
159
- assert saved == [["Reviewer"]]
160
-
161
-
162
- def test_create_role_filters_assistant_only_tools(monkeypatch):
163
- settings = Settings()
164
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
165
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
166
-
167
- result = asyncio.run(
168
- create_role(
169
- CreateRoleRequest(
170
- name="Reviewer",
171
- description="Review code carefully",
172
- system_prompt="Review code carefully",
173
- included_tools=[
174
- "read",
175
- "create_workflow",
176
- "delete_workflow",
177
- "list_workflows",
178
- "manage_settings",
179
- ],
180
- excluded_tools=["fetch"],
181
- )
182
- )
183
- )
184
-
185
- assert result["included_tools"] == ["read"]
186
- assert result["excluded_tools"] == ["fetch"]
187
- assert settings.roles[0].included_tools == ["read"]
188
- assert settings.roles[0].excluded_tools == ["fetch"]
189
-
190
-
191
- def test_create_role_rejects_duplicate_name(monkeypatch):
192
- settings = Settings(
193
- roles=[RoleConfig(name="Reviewer", system_prompt="Review code carefully")]
194
- )
195
-
196
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
197
-
198
- with pytest.raises(HTTPException) as excinfo:
199
- asyncio.run(
200
- create_role(
201
- CreateRoleRequest(
202
- name="Reviewer",
203
- description="Different description",
204
- system_prompt="Different prompt",
205
- )
206
- )
207
- )
208
-
209
- assert excinfo.value.status_code == 409
210
- assert excinfo.value.detail == "Role 'Reviewer' already exists"
211
-
212
-
213
- def test_update_role_uses_name_path_parameter(monkeypatch):
214
- settings = Settings(
215
- roles=[
216
- RoleConfig(
217
- name="Reviewer",
218
- description="Review code carefully",
219
- system_prompt="Review code carefully",
220
- included_tools=["read"],
221
- )
222
- ]
223
- )
224
- saved: list[list[str]] = []
225
-
226
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
227
- monkeypatch.setattr(
228
- "flowent.routes.roles.save_settings",
229
- lambda current: saved.append([role.name for role in current.roles]),
230
- )
231
-
232
- result = asyncio.run(
233
- update_role(
234
- "Reviewer",
235
- UpdateRoleRequest(
236
- name="Architect",
237
- description="Design systems role",
238
- system_prompt="Design systems",
239
- excluded_tools=["fetch"],
240
- ),
241
- )
242
- )
243
-
244
- assert result == {
245
- "name": "Architect",
246
- "description": "Design systems role",
247
- "system_prompt": "Design systems",
248
- "model": None,
249
- "model_params": None,
250
- "included_tools": ["read"],
251
- "excluded_tools": ["fetch"],
252
- "is_builtin": False,
253
- }
254
- assert settings.roles == [
255
- RoleConfig(
256
- name="Architect",
257
- description="Design systems role",
258
- system_prompt="Design systems",
259
- included_tools=["read"],
260
- excluded_tools=["fetch"],
261
- )
262
- ]
263
- assert saved == [["Architect"]]
264
-
265
-
266
- def test_update_role_filters_assistant_only_tools(monkeypatch):
267
- settings = Settings(
268
- roles=[
269
- RoleConfig(
270
- name="Reviewer",
271
- description="Review code carefully",
272
- system_prompt="Review code carefully",
273
- included_tools=["read"],
274
- )
275
- ]
276
- )
277
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
278
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
279
-
280
- result = asyncio.run(
281
- update_role(
282
- "Reviewer",
283
- UpdateRoleRequest(
284
- included_tools=[
285
- "read",
286
- "create_workflow",
287
- "delete_workflow",
288
- "list_workflows",
289
- "manage_roles",
290
- ],
291
- excluded_tools=["fetch"],
292
- ),
293
- )
294
- )
295
-
296
- assert result["included_tools"] == ["read"]
297
- assert result["excluded_tools"] == ["fetch"]
298
- assert settings.roles[0].included_tools == ["read"]
299
- assert settings.roles[0].excluded_tools == ["fetch"]
300
-
301
-
302
- def test_update_role_rejects_duplicate_name(monkeypatch):
303
- settings = Settings(
304
- roles=[
305
- RoleConfig(name="Reviewer", system_prompt="Review code carefully"),
306
- RoleConfig(name="Architect", system_prompt="Design systems"),
307
- ]
308
- )
309
-
310
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
311
-
312
- with pytest.raises(HTTPException) as excinfo:
313
- asyncio.run(update_role("Reviewer", UpdateRoleRequest(name="Architect")))
314
-
315
- assert excinfo.value.status_code == 409
316
- assert excinfo.value.detail == "Role 'Architect' already exists"
317
-
318
-
319
- @pytest.mark.parametrize(
320
- "builtin_role_name",
321
- ["Worker", CONDUCTOR_ROLE_NAME, DESIGNER_ROLE_NAME],
322
- )
323
- def test_update_role_rejects_renaming_builtin_role(monkeypatch, builtin_role_name):
324
- settings = Settings(
325
- roles=[RoleConfig(name=builtin_role_name, system_prompt="Do work.")]
326
- )
327
-
328
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
329
-
330
- with pytest.raises(HTTPException) as excinfo:
331
- asyncio.run(update_role(builtin_role_name, UpdateRoleRequest(name="Helper")))
332
-
333
- assert excinfo.value.status_code == 400
334
- assert excinfo.value.detail == f"Cannot rename built-in role '{builtin_role_name}'"
335
-
336
-
337
- def test_update_role_rejects_builtin_prompt_change(monkeypatch):
338
- settings = Settings(
339
- roles=[
340
- RoleConfig(name="Worker", system_prompt="Do work.", included_tools=["read"])
341
- ]
342
- )
343
-
344
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
345
-
346
- with pytest.raises(HTTPException) as excinfo:
347
- asyncio.run(
348
- update_role(
349
- "Worker",
350
- UpdateRoleRequest(system_prompt="Different prompt"),
351
- )
352
- )
353
-
354
- assert excinfo.value.status_code == 400
355
- assert (
356
- excinfo.value.detail
357
- == "Cannot modify built-in role 'Worker' fields other than model or model_params"
358
- )
359
-
360
-
361
- def test_update_builtin_steward_role_model_preserves_management_tools(monkeypatch):
362
- settings = Settings(
363
- providers=[
364
- ProviderConfig(
365
- id="provider-1",
366
- name="OpenAI",
367
- type="openai",
368
- base_url="https://api.openai.com/v1",
369
- api_key="sk-test",
370
- models=[
371
- ProviderModelCatalogEntry(
372
- model="gpt-4.1-mini",
373
- )
374
- ],
375
- )
376
- ],
377
- roles=[
378
- RoleConfig(
379
- name=STEWARD_ROLE_NAME,
380
- description="Assistant role",
381
- system_prompt="Help coordinate work.",
382
- included_tools=list(STEWARD_ROLE_INCLUDED_TOOLS),
383
- )
384
- ],
385
- )
386
-
387
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
388
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
389
-
390
- result = asyncio.run(
391
- update_role(
392
- STEWARD_ROLE_NAME,
393
- UpdateRoleRequest(
394
- model=RoleModelRequest(
395
- provider_id="provider-1",
396
- model="gpt-4.1-mini",
397
- )
398
- ),
399
- )
400
- )
401
-
402
- assert result["included_tools"] == list(STEWARD_ROLE_INCLUDED_TOOLS)
403
- assert settings.roles[0].included_tools == list(STEWARD_ROLE_INCLUDED_TOOLS)
404
-
405
-
406
- def test_delete_role_uses_name_path_parameter(monkeypatch):
407
- settings = Settings(
408
- roles=[
409
- RoleConfig(name="Reviewer", system_prompt="Review code carefully"),
410
- RoleConfig(name="Architect", system_prompt="Design systems"),
411
- ]
412
- )
413
- saved: list[list[str]] = []
414
-
415
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
416
- monkeypatch.setattr(
417
- "flowent.routes.roles.save_settings",
418
- lambda current: saved.append([role.name for role in current.roles]),
419
- )
420
-
421
- result = asyncio.run(delete_role("Reviewer"))
422
-
423
- assert result == {"status": "deleted"}
424
- assert settings.roles == [
425
- RoleConfig(name="Architect", system_prompt="Design systems")
426
- ]
427
- assert saved == [["Architect"]]
428
-
429
-
430
- @pytest.mark.parametrize(
431
- "builtin_role_name",
432
- ["Worker", CONDUCTOR_ROLE_NAME, DESIGNER_ROLE_NAME],
433
- )
434
- def test_delete_role_rejects_builtin_role(monkeypatch, builtin_role_name):
435
- settings = Settings(
436
- roles=[RoleConfig(name=builtin_role_name, system_prompt="Do work.")]
437
- )
438
-
439
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
440
-
441
- with pytest.raises(HTTPException) as excinfo:
442
- asyncio.run(delete_role(builtin_role_name))
443
-
444
- assert excinfo.value.status_code == 400
445
- assert excinfo.value.detail == f"Cannot delete built-in role '{builtin_role_name}'"
446
-
447
-
448
- def test_create_role_rejects_overlapping_included_and_excluded_tools(monkeypatch):
449
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: Settings())
450
-
451
- with pytest.raises(HTTPException) as excinfo:
452
- asyncio.run(
453
- create_role(
454
- CreateRoleRequest(
455
- name="Reviewer",
456
- description="Review code carefully",
457
- system_prompt="Review code carefully",
458
- included_tools=["read"],
459
- excluded_tools=["read"],
460
- )
461
- )
462
- )
463
-
464
- assert excinfo.value.status_code == 400
465
- assert (
466
- excinfo.value.detail == "included_tools and excluded_tools cannot overlap: read"
467
- )
468
-
469
-
470
- def test_update_role_persists_model(monkeypatch):
471
- settings = Settings(
472
- providers=[
473
- ProviderConfig(
474
- id="provider-1",
475
- name="Primary",
476
- type="openai_compatible",
477
- base_url="https://api.example.com/v1",
478
- api_key="secret",
479
- )
480
- ],
481
- roles=[RoleConfig(name="Reviewer", system_prompt="Review carefully")],
482
- )
483
-
484
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
485
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
486
-
487
- result = asyncio.run(
488
- update_role(
489
- "Reviewer",
490
- UpdateRoleRequest(
491
- model=RoleModelRequest(
492
- provider_id="provider-1",
493
- model="gpt-4.1-mini",
494
- )
495
- ),
496
- )
497
- )
498
-
499
- assert result["model"] == {
500
- "provider_id": "provider-1",
501
- "model": "gpt-4.1-mini",
502
- }
503
- assert settings.roles[0].model == RoleModelConfig(
504
- provider_id="provider-1",
505
- model="gpt-4.1-mini",
506
- )
507
-
508
-
509
- def test_update_role_renames_selected_assistant_role(monkeypatch):
510
- settings = Settings(
511
- assistant=AssistantSettings(role_name="Reviewer"),
512
- roles=[RoleConfig(name="Reviewer", system_prompt="Review carefully")],
513
- )
514
-
515
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
516
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
517
-
518
- asyncio.run(
519
- update_role(
520
- "Reviewer",
521
- UpdateRoleRequest(name="Architect"),
522
- )
523
- )
524
-
525
- assert settings.assistant.role_name == "Architect"
526
-
527
-
528
- def test_delete_role_resets_selected_assistant_role_to_steward(monkeypatch):
529
- settings = Settings(
530
- assistant=AssistantSettings(role_name="Reviewer"),
531
- roles=[RoleConfig(name="Reviewer", system_prompt="Review carefully")],
532
- )
533
-
534
- monkeypatch.setattr("flowent.routes.roles.get_settings", lambda: settings)
535
- monkeypatch.setattr("flowent.routes.roles.save_settings", lambda current: None)
536
-
537
- asyncio.run(delete_role("Reviewer"))
538
-
539
- assert settings.assistant.role_name == "Steward"