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