@jcjeon/integration-cli 0.2.0 → 0.2.1

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 (820) hide show
  1. package/apps/server/dist/app.controller.d.ts +6 -0
  2. package/apps/server/dist/app.controller.js +35 -0
  3. package/apps/server/dist/app.controller.js.map +1 -0
  4. package/apps/server/dist/app.module.d.ts +2 -0
  5. package/apps/server/dist/app.module.js +30 -0
  6. package/apps/server/dist/app.module.js.map +1 -0
  7. package/apps/server/dist/app.service.d.ts +3 -0
  8. package/apps/server/dist/app.service.js +20 -0
  9. package/apps/server/dist/app.service.js.map +1 -0
  10. package/apps/server/dist/common/ji-paths.d.ts +22 -0
  11. package/apps/server/dist/common/ji-paths.js +77 -0
  12. package/apps/server/dist/common/ji-paths.js.map +1 -0
  13. package/apps/server/dist/database/database.module.d.ts +2 -0
  14. package/apps/server/dist/database/database.module.js +38 -0
  15. package/apps/server/dist/database/database.module.js.map +1 -0
  16. package/apps/server/dist/database/entities/agent-changelog.entity.d.ts +14 -0
  17. package/apps/server/dist/database/entities/agent-changelog.entity.js +75 -0
  18. package/apps/server/dist/database/entities/agent-changelog.entity.js.map +1 -0
  19. package/apps/server/dist/database/entities/agent-session.entity.d.ts +10 -0
  20. package/apps/server/dist/database/entities/agent-session.entity.js +60 -0
  21. package/apps/server/dist/database/entities/agent-session.entity.js.map +1 -0
  22. package/apps/server/dist/database/entities/conversation.entity.d.ts +12 -0
  23. package/apps/server/dist/database/entities/conversation.entity.js +66 -0
  24. package/apps/server/dist/database/entities/conversation.entity.js.map +1 -0
  25. package/apps/server/dist/database/entities/session.entity.d.ts +6 -0
  26. package/apps/server/dist/database/entities/session.entity.js +40 -0
  27. package/apps/server/dist/database/entities/session.entity.js.map +1 -0
  28. package/apps/server/dist/database/entities/task-agent-run.entity.d.ts +15 -0
  29. package/apps/server/dist/database/entities/task-agent-run.entity.js +77 -0
  30. package/apps/server/dist/database/entities/task-agent-run.entity.js.map +1 -0
  31. package/apps/server/dist/database/entities/task-agent.entity.d.ts +16 -0
  32. package/apps/server/dist/database/entities/task-agent.entity.js +76 -0
  33. package/apps/server/dist/database/entities/task-agent.entity.js.map +1 -0
  34. package/apps/server/dist/database/entities/task-requirement.entity.d.ts +10 -0
  35. package/apps/server/dist/database/entities/task-requirement.entity.js +56 -0
  36. package/apps/server/dist/database/entities/task-requirement.entity.js.map +1 -0
  37. package/apps/server/dist/database/entities/task-run.entity.d.ts +13 -0
  38. package/apps/server/dist/database/entities/task-run.entity.js +67 -0
  39. package/apps/server/dist/database/entities/task-run.entity.js.map +1 -0
  40. package/apps/server/dist/database/entities/task.entity.d.ts +14 -0
  41. package/apps/server/dist/database/entities/task.entity.js +72 -0
  42. package/apps/server/dist/database/entities/task.entity.js.map +1 -0
  43. package/apps/server/dist/main.d.ts +1 -0
  44. package/apps/server/dist/main.js +81 -0
  45. package/apps/server/dist/main.js.map +1 -0
  46. package/apps/server/dist/modules/agents/agents.module.d.ts +2 -0
  47. package/apps/server/dist/modules/agents/agents.module.js +23 -0
  48. package/apps/server/dist/modules/agents/agents.module.js.map +1 -0
  49. package/apps/server/dist/modules/agents/claude/claude-auth.manager.d.ts +15 -0
  50. package/apps/server/dist/modules/agents/claude/claude-auth.manager.js +71 -0
  51. package/apps/server/dist/modules/agents/claude/claude-auth.manager.js.map +1 -0
  52. package/apps/server/dist/modules/agents/claude/claude-pty.manager.d.ts +29 -0
  53. package/apps/server/dist/modules/agents/claude/claude-pty.manager.js +372 -0
  54. package/apps/server/dist/modules/agents/claude/claude-pty.manager.js.map +1 -0
  55. package/apps/server/dist/modules/agents/claude/claude.controller.d.ts +19 -0
  56. package/apps/server/dist/modules/agents/claude/claude.controller.js +125 -0
  57. package/apps/server/dist/modules/agents/claude/claude.controller.js.map +1 -0
  58. package/apps/server/dist/modules/agents/claude/claude.gateway.d.ts +27 -0
  59. package/apps/server/dist/modules/agents/claude/claude.gateway.js +148 -0
  60. package/apps/server/dist/modules/agents/claude/claude.gateway.js.map +1 -0
  61. package/apps/server/dist/modules/agents/claude/claude.module.d.ts +2 -0
  62. package/apps/server/dist/modules/agents/claude/claude.module.js +30 -0
  63. package/apps/server/dist/modules/agents/claude/claude.module.js.map +1 -0
  64. package/apps/server/dist/modules/agents/claude/claude.service.d.ts +28 -0
  65. package/apps/server/dist/modules/agents/claude/claude.service.js +94 -0
  66. package/apps/server/dist/modules/agents/claude/claude.service.js.map +1 -0
  67. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.d.ts +6 -0
  68. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.js +46 -0
  69. package/apps/server/dist/modules/agents/claude/dto/create-session.dto.js.map +1 -0
  70. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.d.ts +4 -0
  71. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.js +31 -0
  72. package/apps/server/dist/modules/agents/claude/dto/resize-session.dto.js.map +1 -0
  73. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.d.ts +3 -0
  74. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.js +25 -0
  75. package/apps/server/dist/modules/agents/claude/dto/send-input.dto.js.map +1 -0
  76. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.d.ts +22 -0
  77. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.js +3 -0
  78. package/apps/server/dist/modules/agents/claude/interfaces/claude-session.interface.js.map +1 -0
  79. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.d.ts +9 -0
  80. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.js +3 -0
  81. package/apps/server/dist/modules/agents/claude/interfaces/pty-event.interface.js.map +1 -0
  82. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.d.ts +53 -0
  83. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.js +3 -0
  84. package/apps/server/dist/modules/agents/claude/interfaces/stream-event.interface.js.map +1 -0
  85. package/apps/server/dist/modules/agents/codex/codex-auth.manager.d.ts +16 -0
  86. package/apps/server/dist/modules/agents/codex/codex-auth.manager.js +136 -0
  87. package/apps/server/dist/modules/agents/codex/codex-auth.manager.js.map +1 -0
  88. package/apps/server/dist/modules/agents/codex/codex-session.manager.d.ts +37 -0
  89. package/apps/server/dist/modules/agents/codex/codex-session.manager.js +319 -0
  90. package/apps/server/dist/modules/agents/codex/codex-session.manager.js.map +1 -0
  91. package/apps/server/dist/modules/agents/codex/codex.controller.d.ts +19 -0
  92. package/apps/server/dist/modules/agents/codex/codex.controller.js +95 -0
  93. package/apps/server/dist/modules/agents/codex/codex.controller.js.map +1 -0
  94. package/apps/server/dist/modules/agents/codex/codex.gateway.d.ts +27 -0
  95. package/apps/server/dist/modules/agents/codex/codex.gateway.js +123 -0
  96. package/apps/server/dist/modules/agents/codex/codex.gateway.js.map +1 -0
  97. package/apps/server/dist/modules/agents/codex/codex.module.d.ts +2 -0
  98. package/apps/server/dist/modules/agents/codex/codex.module.js +29 -0
  99. package/apps/server/dist/modules/agents/codex/codex.module.js.map +1 -0
  100. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.d.ts +3 -0
  101. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.js +23 -0
  102. package/apps/server/dist/modules/agents/codex/dto/configure-auth.dto.js.map +1 -0
  103. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.d.ts +5 -0
  104. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.js +31 -0
  105. package/apps/server/dist/modules/agents/gemini/dto/configure-auth.dto.js.map +1 -0
  106. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.d.ts +3 -0
  107. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.js +25 -0
  108. package/apps/server/dist/modules/agents/gemini/dto/create-session.dto.js.map +1 -0
  109. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.d.ts +3 -0
  110. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.js +25 -0
  111. package/apps/server/dist/modules/agents/gemini/dto/send-input.dto.js.map +1 -0
  112. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.d.ts +20 -0
  113. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.js +154 -0
  114. package/apps/server/dist/modules/agents/gemini/gemini-auth.manager.js.map +1 -0
  115. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.d.ts +31 -0
  116. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.js +304 -0
  117. package/apps/server/dist/modules/agents/gemini/gemini-session.manager.js.map +1 -0
  118. package/apps/server/dist/modules/agents/gemini/gemini.controller.d.ts +19 -0
  119. package/apps/server/dist/modules/agents/gemini/gemini.controller.js +135 -0
  120. package/apps/server/dist/modules/agents/gemini/gemini.controller.js.map +1 -0
  121. package/apps/server/dist/modules/agents/gemini/gemini.gateway.d.ts +24 -0
  122. package/apps/server/dist/modules/agents/gemini/gemini.gateway.js +142 -0
  123. package/apps/server/dist/modules/agents/gemini/gemini.gateway.js.map +1 -0
  124. package/apps/server/dist/modules/agents/gemini/gemini.module.d.ts +2 -0
  125. package/apps/server/dist/modules/agents/gemini/gemini.module.js +29 -0
  126. package/apps/server/dist/modules/agents/gemini/gemini.module.js.map +1 -0
  127. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.d.ts +16 -0
  128. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.js +3 -0
  129. package/apps/server/dist/modules/agents/gemini/interfaces/gemini-session.interface.js.map +1 -0
  130. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.d.ts +12 -0
  131. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.js +3 -0
  132. package/apps/server/dist/modules/agents/gemini/interfaces/stream-event.interface.js.map +1 -0
  133. package/apps/server/dist/modules/changelog/changelog.controller.d.ts +7 -0
  134. package/apps/server/dist/modules/changelog/changelog.controller.js +50 -0
  135. package/apps/server/dist/modules/changelog/changelog.controller.js.map +1 -0
  136. package/apps/server/dist/modules/changelog/changelog.module.d.ts +2 -0
  137. package/apps/server/dist/modules/changelog/changelog.module.js +26 -0
  138. package/apps/server/dist/modules/changelog/changelog.module.js.map +1 -0
  139. package/apps/server/dist/modules/changelog/changelog.service.d.ts +68 -0
  140. package/apps/server/dist/modules/changelog/changelog.service.js +598 -0
  141. package/apps/server/dist/modules/changelog/changelog.service.js.map +1 -0
  142. package/apps/server/dist/modules/conversations/conversation.controller.d.ts +11 -0
  143. package/apps/server/dist/modules/conversations/conversation.controller.js +95 -0
  144. package/apps/server/dist/modules/conversations/conversation.controller.js.map +1 -0
  145. package/apps/server/dist/modules/conversations/conversation.module.d.ts +2 -0
  146. package/apps/server/dist/modules/conversations/conversation.module.js +26 -0
  147. package/apps/server/dist/modules/conversations/conversation.module.js.map +1 -0
  148. package/apps/server/dist/modules/conversations/conversation.service.d.ts +13 -0
  149. package/apps/server/dist/modules/conversations/conversation.service.js +61 -0
  150. package/apps/server/dist/modules/conversations/conversation.service.js.map +1 -0
  151. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.d.ts +10 -0
  152. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.js +64 -0
  153. package/apps/server/dist/modules/conversations/dto/create-conversation.dto.js.map +1 -0
  154. package/apps/server/dist/modules/conversations/enums/conversation.enum.d.ts +12 -0
  155. package/apps/server/dist/modules/conversations/enums/conversation.enum.js +18 -0
  156. package/apps/server/dist/modules/conversations/enums/conversation.enum.js.map +1 -0
  157. package/apps/server/dist/modules/fs/fs.controller.d.ts +6 -0
  158. package/apps/server/dist/modules/fs/fs.controller.js +85 -0
  159. package/apps/server/dist/modules/fs/fs.controller.js.map +1 -0
  160. package/apps/server/dist/modules/fs/fs.module.d.ts +2 -0
  161. package/apps/server/dist/modules/fs/fs.module.js +20 -0
  162. package/apps/server/dist/modules/fs/fs.module.js.map +1 -0
  163. package/apps/server/dist/modules/harness/dto/save-harness.dto.d.ts +4 -0
  164. package/apps/server/dist/modules/harness/dto/save-harness.dto.js +27 -0
  165. package/apps/server/dist/modules/harness/dto/save-harness.dto.js.map +1 -0
  166. package/apps/server/dist/modules/harness/harness.controller.d.ts +14 -0
  167. package/apps/server/dist/modules/harness/harness.controller.js +72 -0
  168. package/apps/server/dist/modules/harness/harness.controller.js.map +1 -0
  169. package/apps/server/dist/modules/harness/harness.module.d.ts +2 -0
  170. package/apps/server/dist/modules/harness/harness.module.js +23 -0
  171. package/apps/server/dist/modules/harness/harness.module.js.map +1 -0
  172. package/apps/server/dist/modules/harness/harness.service.d.ts +20 -0
  173. package/apps/server/dist/modules/harness/harness.service.js +134 -0
  174. package/apps/server/dist/modules/harness/harness.service.js.map +1 -0
  175. package/apps/server/dist/modules/sessions/session.controller.d.ts +12 -0
  176. package/apps/server/dist/modules/sessions/session.controller.js +79 -0
  177. package/apps/server/dist/modules/sessions/session.controller.js.map +1 -0
  178. package/apps/server/dist/modules/sessions/session.module.d.ts +2 -0
  179. package/apps/server/dist/modules/sessions/session.module.js +26 -0
  180. package/apps/server/dist/modules/sessions/session.module.js.map +1 -0
  181. package/apps/server/dist/modules/sessions/session.service.d.ts +9 -0
  182. package/apps/server/dist/modules/sessions/session.service.js +49 -0
  183. package/apps/server/dist/modules/sessions/session.service.js.map +1 -0
  184. package/apps/server/dist/modules/tasks/dto/create-task.dto.d.ts +15 -0
  185. package/apps/server/dist/modules/tasks/dto/create-task.dto.js +88 -0
  186. package/apps/server/dist/modules/tasks/dto/create-task.dto.js.map +1 -0
  187. package/apps/server/dist/modules/tasks/dto/execute-task.dto.d.ts +7 -0
  188. package/apps/server/dist/modules/tasks/dto/execute-task.dto.js +43 -0
  189. package/apps/server/dist/modules/tasks/dto/execute-task.dto.js.map +1 -0
  190. package/apps/server/dist/modules/tasks/dto/merge-file.dto.d.ts +3 -0
  191. package/apps/server/dist/modules/tasks/dto/merge-file.dto.js +23 -0
  192. package/apps/server/dist/modules/tasks/dto/merge-file.dto.js.map +1 -0
  193. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.d.ts +4 -0
  194. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.js +32 -0
  195. package/apps/server/dist/modules/tasks/dto/rerun-task.dto.js.map +1 -0
  196. package/apps/server/dist/modules/tasks/dto/update-task.dto.d.ts +15 -0
  197. package/apps/server/dist/modules/tasks/dto/update-task.dto.js +89 -0
  198. package/apps/server/dist/modules/tasks/dto/update-task.dto.js.map +1 -0
  199. package/apps/server/dist/modules/tasks/task-execution.service.d.ts +105 -0
  200. package/apps/server/dist/modules/tasks/task-execution.service.js +842 -0
  201. package/apps/server/dist/modules/tasks/task-execution.service.js.map +1 -0
  202. package/apps/server/dist/modules/tasks/task.gateway.d.ts +17 -0
  203. package/apps/server/dist/modules/tasks/task.gateway.js +126 -0
  204. package/apps/server/dist/modules/tasks/task.gateway.js.map +1 -0
  205. package/apps/server/dist/modules/tasks/tasks.controller.d.ts +29 -0
  206. package/apps/server/dist/modules/tasks/tasks.controller.js +209 -0
  207. package/apps/server/dist/modules/tasks/tasks.controller.js.map +1 -0
  208. package/apps/server/dist/modules/tasks/tasks.module.d.ts +2 -0
  209. package/apps/server/dist/modules/tasks/tasks.module.js +42 -0
  210. package/apps/server/dist/modules/tasks/tasks.module.js.map +1 -0
  211. package/apps/server/dist/modules/tasks/tasks.service.d.ts +47 -0
  212. package/apps/server/dist/modules/tasks/tasks.service.js +341 -0
  213. package/apps/server/dist/modules/tasks/tasks.service.js.map +1 -0
  214. package/apps/server/dist/tsconfig.build.tsbuildinfo +1 -0
  215. package/apps/web/.next/BUILD_ID +1 -0
  216. package/apps/web/.next/app-path-routes-manifest.json +12 -0
  217. package/apps/web/.next/build/chunks/[root-of-the-server]__0cstldc._.js +206 -0
  218. package/apps/web/.next/build/chunks/[root-of-the-server]__0cstldc._.js.map +8 -0
  219. package/apps/web/.next/build/chunks/[root-of-the-server]__0s3ts0r._.js +500 -0
  220. package/apps/web/.next/build/chunks/[root-of-the-server]__0s3ts0r._.js.map +11 -0
  221. package/apps/web/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_0xqnjlz._.js +13 -0
  222. package/apps/web/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_0xqnjlz._.js.map +5 -0
  223. package/apps/web/.next/build/chunks/[turbopack]_runtime.js +890 -0
  224. package/apps/web/.next/build/chunks/[turbopack]_runtime.js.map +11 -0
  225. package/apps/web/.next/build/chunks/node_modules_13sb.px._.js +6820 -0
  226. package/apps/web/.next/build/chunks/node_modules_13sb.px._.js.map +47 -0
  227. package/apps/web/.next/build/package.json +1 -0
  228. package/apps/web/.next/build/postcss.js +6 -0
  229. package/apps/web/.next/build/postcss.js.map +5 -0
  230. package/apps/web/.next/build-manifest.json +21 -0
  231. package/apps/web/.next/diagnostics/build-diagnostics.json +6 -0
  232. package/apps/web/.next/diagnostics/framework.json +1 -0
  233. package/apps/web/.next/diagnostics/route-bundle-stats.json +118 -0
  234. package/apps/web/.next/export-marker.json +6 -0
  235. package/apps/web/.next/fallback-build-manifest.json +13 -0
  236. package/apps/web/.next/images-manifest.json +68 -0
  237. package/apps/web/.next/next-minimal-server.js.nft.json +1 -0
  238. package/apps/web/.next/next-server.js.nft.json +1 -0
  239. package/apps/web/.next/package.json +1 -0
  240. package/apps/web/.next/prerender-manifest.json +234 -0
  241. package/apps/web/.next/required-server-files.js +332 -0
  242. package/apps/web/.next/required-server-files.json +332 -0
  243. package/apps/web/.next/routes-manifest.json +108 -0
  244. package/apps/web/.next/server/app/_global-error/page/app-paths-manifest.json +3 -0
  245. package/apps/web/.next/server/app/_global-error/page/build-manifest.json +17 -0
  246. package/apps/web/.next/server/app/_global-error/page/next-font-manifest.json +6 -0
  247. package/apps/web/.next/server/app/_global-error/page/react-loadable-manifest.json +1 -0
  248. package/apps/web/.next/server/app/_global-error/page/server-reference-manifest.json +4 -0
  249. package/apps/web/.next/server/app/_global-error/page.js +10 -0
  250. package/apps/web/.next/server/app/_global-error/page.js.map +5 -0
  251. package/apps/web/.next/server/app/_global-error/page.js.nft.json +1 -0
  252. package/apps/web/.next/server/app/_global-error/page_client-reference-manifest.js +3 -0
  253. package/apps/web/.next/server/app/_global-error.html +1 -0
  254. package/apps/web/.next/server/app/_global-error.meta +15 -0
  255. package/apps/web/.next/server/app/_global-error.rsc +15 -0
  256. package/apps/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +5 -0
  257. package/apps/web/.next/server/app/_global-error.segments/_full.segment.rsc +15 -0
  258. package/apps/web/.next/server/app/_global-error.segments/_head.segment.rsc +6 -0
  259. package/apps/web/.next/server/app/_global-error.segments/_index.segment.rsc +5 -0
  260. package/apps/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -0
  261. package/apps/web/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
  262. package/apps/web/.next/server/app/_not-found/page/build-manifest.json +17 -0
  263. package/apps/web/.next/server/app/_not-found/page/next-font-manifest.json +11 -0
  264. package/apps/web/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
  265. package/apps/web/.next/server/app/_not-found/page/server-reference-manifest.json +4 -0
  266. package/apps/web/.next/server/app/_not-found/page.js +13 -0
  267. package/apps/web/.next/server/app/_not-found/page.js.map +5 -0
  268. package/apps/web/.next/server/app/_not-found/page.js.nft.json +1 -0
  269. package/apps/web/.next/server/app/_not-found/page_client-reference-manifest.js +3 -0
  270. package/apps/web/.next/server/app/_not-found.html +1 -0
  271. package/apps/web/.next/server/app/_not-found.meta +16 -0
  272. package/apps/web/.next/server/app/_not-found.rsc +19 -0
  273. package/apps/web/.next/server/app/_not-found.segments/_full.segment.rsc +19 -0
  274. package/apps/web/.next/server/app/_not-found.segments/_head.segment.rsc +6 -0
  275. package/apps/web/.next/server/app/_not-found.segments/_index.segment.rsc +8 -0
  276. package/apps/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +5 -0
  277. package/apps/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +5 -0
  278. package/apps/web/.next/server/app/_not-found.segments/_tree.segment.rsc +3 -0
  279. package/apps/web/.next/server/app/claude/page/app-paths-manifest.json +3 -0
  280. package/apps/web/.next/server/app/claude/page/build-manifest.json +17 -0
  281. package/apps/web/.next/server/app/claude/page/next-font-manifest.json +11 -0
  282. package/apps/web/.next/server/app/claude/page/react-loadable-manifest.json +1 -0
  283. package/apps/web/.next/server/app/claude/page/server-reference-manifest.json +4 -0
  284. package/apps/web/.next/server/app/claude/page.js +14 -0
  285. package/apps/web/.next/server/app/claude/page.js.map +5 -0
  286. package/apps/web/.next/server/app/claude/page.js.nft.json +1 -0
  287. package/apps/web/.next/server/app/claude/page_client-reference-manifest.js +3 -0
  288. package/apps/web/.next/server/app/claude.html +1 -0
  289. package/apps/web/.next/server/app/claude.meta +15 -0
  290. package/apps/web/.next/server/app/claude.rsc +22 -0
  291. package/apps/web/.next/server/app/claude.segments/_full.segment.rsc +22 -0
  292. package/apps/web/.next/server/app/claude.segments/_head.segment.rsc +6 -0
  293. package/apps/web/.next/server/app/claude.segments/_index.segment.rsc +8 -0
  294. package/apps/web/.next/server/app/claude.segments/_tree.segment.rsc +5 -0
  295. package/apps/web/.next/server/app/claude.segments/claude/__PAGE__.segment.rsc +6 -0
  296. package/apps/web/.next/server/app/claude.segments/claude.segment.rsc +5 -0
  297. package/apps/web/.next/server/app/codex/page/app-paths-manifest.json +3 -0
  298. package/apps/web/.next/server/app/codex/page/build-manifest.json +17 -0
  299. package/apps/web/.next/server/app/codex/page/next-font-manifest.json +11 -0
  300. package/apps/web/.next/server/app/codex/page/react-loadable-manifest.json +1 -0
  301. package/apps/web/.next/server/app/codex/page/server-reference-manifest.json +4 -0
  302. package/apps/web/.next/server/app/codex/page.js +14 -0
  303. package/apps/web/.next/server/app/codex/page.js.map +5 -0
  304. package/apps/web/.next/server/app/codex/page.js.nft.json +1 -0
  305. package/apps/web/.next/server/app/codex/page_client-reference-manifest.js +3 -0
  306. package/apps/web/.next/server/app/codex.html +1 -0
  307. package/apps/web/.next/server/app/codex.meta +15 -0
  308. package/apps/web/.next/server/app/codex.rsc +25 -0
  309. package/apps/web/.next/server/app/codex.segments/_full.segment.rsc +25 -0
  310. package/apps/web/.next/server/app/codex.segments/_head.segment.rsc +6 -0
  311. package/apps/web/.next/server/app/codex.segments/_index.segment.rsc +8 -0
  312. package/apps/web/.next/server/app/codex.segments/_tree.segment.rsc +5 -0
  313. package/apps/web/.next/server/app/codex.segments/codex/__PAGE__.segment.rsc +9 -0
  314. package/apps/web/.next/server/app/codex.segments/codex.segment.rsc +5 -0
  315. package/apps/web/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
  316. package/apps/web/.next/server/app/favicon.ico/route/build-manifest.json +9 -0
  317. package/apps/web/.next/server/app/favicon.ico/route.js +6 -0
  318. package/apps/web/.next/server/app/favicon.ico/route.js.map +5 -0
  319. package/apps/web/.next/server/app/favicon.ico/route.js.nft.json +1 -0
  320. package/apps/web/.next/server/app/favicon.ico.meta +1 -0
  321. package/apps/web/.next/server/app/gemini/page/app-paths-manifest.json +3 -0
  322. package/apps/web/.next/server/app/gemini/page/build-manifest.json +17 -0
  323. package/apps/web/.next/server/app/gemini/page/next-font-manifest.json +11 -0
  324. package/apps/web/.next/server/app/gemini/page/react-loadable-manifest.json +1 -0
  325. package/apps/web/.next/server/app/gemini/page/server-reference-manifest.json +4 -0
  326. package/apps/web/.next/server/app/gemini/page.js +14 -0
  327. package/apps/web/.next/server/app/gemini/page.js.map +5 -0
  328. package/apps/web/.next/server/app/gemini/page.js.nft.json +1 -0
  329. package/apps/web/.next/server/app/gemini/page_client-reference-manifest.js +3 -0
  330. package/apps/web/.next/server/app/gemini.html +1 -0
  331. package/apps/web/.next/server/app/gemini.meta +15 -0
  332. package/apps/web/.next/server/app/gemini.rsc +25 -0
  333. package/apps/web/.next/server/app/gemini.segments/_full.segment.rsc +25 -0
  334. package/apps/web/.next/server/app/gemini.segments/_head.segment.rsc +6 -0
  335. package/apps/web/.next/server/app/gemini.segments/_index.segment.rsc +8 -0
  336. package/apps/web/.next/server/app/gemini.segments/_tree.segment.rsc +5 -0
  337. package/apps/web/.next/server/app/gemini.segments/gemini/__PAGE__.segment.rsc +9 -0
  338. package/apps/web/.next/server/app/gemini.segments/gemini.segment.rsc +5 -0
  339. package/apps/web/.next/server/app/index.html +1 -0
  340. package/apps/web/.next/server/app/index.meta +14 -0
  341. package/apps/web/.next/server/app/index.rsc +23 -0
  342. package/apps/web/.next/server/app/index.segments/__PAGE__.segment.rsc +9 -0
  343. package/apps/web/.next/server/app/index.segments/_full.segment.rsc +23 -0
  344. package/apps/web/.next/server/app/index.segments/_head.segment.rsc +6 -0
  345. package/apps/web/.next/server/app/index.segments/_index.segment.rsc +8 -0
  346. package/apps/web/.next/server/app/index.segments/_tree.segment.rsc +5 -0
  347. package/apps/web/.next/server/app/login/page/app-paths-manifest.json +3 -0
  348. package/apps/web/.next/server/app/login/page/build-manifest.json +17 -0
  349. package/apps/web/.next/server/app/login/page/next-font-manifest.json +11 -0
  350. package/apps/web/.next/server/app/login/page/react-loadable-manifest.json +1 -0
  351. package/apps/web/.next/server/app/login/page/server-reference-manifest.json +4 -0
  352. package/apps/web/.next/server/app/login/page.js +14 -0
  353. package/apps/web/.next/server/app/login/page.js.map +5 -0
  354. package/apps/web/.next/server/app/login/page.js.nft.json +1 -0
  355. package/apps/web/.next/server/app/login/page_client-reference-manifest.js +3 -0
  356. package/apps/web/.next/server/app/login.html +1 -0
  357. package/apps/web/.next/server/app/login.meta +15 -0
  358. package/apps/web/.next/server/app/login.rsc +25 -0
  359. package/apps/web/.next/server/app/login.segments/_full.segment.rsc +25 -0
  360. package/apps/web/.next/server/app/login.segments/_head.segment.rsc +6 -0
  361. package/apps/web/.next/server/app/login.segments/_index.segment.rsc +8 -0
  362. package/apps/web/.next/server/app/login.segments/_tree.segment.rsc +5 -0
  363. package/apps/web/.next/server/app/login.segments/login/__PAGE__.segment.rsc +9 -0
  364. package/apps/web/.next/server/app/login.segments/login.segment.rsc +5 -0
  365. package/apps/web/.next/server/app/page/app-paths-manifest.json +3 -0
  366. package/apps/web/.next/server/app/page/build-manifest.json +17 -0
  367. package/apps/web/.next/server/app/page/next-font-manifest.json +11 -0
  368. package/apps/web/.next/server/app/page/react-loadable-manifest.json +1 -0
  369. package/apps/web/.next/server/app/page/server-reference-manifest.json +4 -0
  370. package/apps/web/.next/server/app/page.js +14 -0
  371. package/apps/web/.next/server/app/page.js.map +5 -0
  372. package/apps/web/.next/server/app/page.js.nft.json +1 -0
  373. package/apps/web/.next/server/app/page_client-reference-manifest.js +3 -0
  374. package/apps/web/.next/server/app/task/[id]/page/app-paths-manifest.json +3 -0
  375. package/apps/web/.next/server/app/task/[id]/page/build-manifest.json +17 -0
  376. package/apps/web/.next/server/app/task/[id]/page/next-font-manifest.json +11 -0
  377. package/apps/web/.next/server/app/task/[id]/page/react-loadable-manifest.json +1 -0
  378. package/apps/web/.next/server/app/task/[id]/page/server-reference-manifest.json +4 -0
  379. package/apps/web/.next/server/app/task/[id]/page.js +14 -0
  380. package/apps/web/.next/server/app/task/[id]/page.js.map +5 -0
  381. package/apps/web/.next/server/app/task/[id]/page.js.nft.json +1 -0
  382. package/apps/web/.next/server/app/task/[id]/page_client-reference-manifest.js +3 -0
  383. package/apps/web/.next/server/app/test/page/app-paths-manifest.json +3 -0
  384. package/apps/web/.next/server/app/test/page/build-manifest.json +17 -0
  385. package/apps/web/.next/server/app/test/page/next-font-manifest.json +11 -0
  386. package/apps/web/.next/server/app/test/page/react-loadable-manifest.json +1 -0
  387. package/apps/web/.next/server/app/test/page/server-reference-manifest.json +4 -0
  388. package/apps/web/.next/server/app/test/page.js +14 -0
  389. package/apps/web/.next/server/app/test/page.js.map +5 -0
  390. package/apps/web/.next/server/app/test/page.js.nft.json +1 -0
  391. package/apps/web/.next/server/app/test/page_client-reference-manifest.js +3 -0
  392. package/apps/web/.next/server/app/test.html +1 -0
  393. package/apps/web/.next/server/app/test.meta +15 -0
  394. package/apps/web/.next/server/app/test.rsc +25 -0
  395. package/apps/web/.next/server/app/test.segments/_full.segment.rsc +25 -0
  396. package/apps/web/.next/server/app/test.segments/_head.segment.rsc +6 -0
  397. package/apps/web/.next/server/app/test.segments/_index.segment.rsc +8 -0
  398. package/apps/web/.next/server/app/test.segments/_tree.segment.rsc +5 -0
  399. package/apps/web/.next/server/app/test.segments/test/__PAGE__.segment.rsc +9 -0
  400. package/apps/web/.next/server/app/test.segments/test.segment.rsc +5 -0
  401. package/apps/web/.next/server/app-paths-manifest.json +12 -0
  402. package/apps/web/.next/server/chunks/[externals]_next_dist_0arv.vj._.js +3 -0
  403. package/apps/web/.next/server/chunks/[externals]_next_dist_0arv.vj._.js.map +1 -0
  404. package/apps/web/.next/server/chunks/[root-of-the-server]__0xjvedo._.js +13 -0
  405. package/apps/web/.next/server/chunks/[root-of-the-server]__0xjvedo._.js.map +1 -0
  406. package/apps/web/.next/server/chunks/[turbopack]_runtime.js +903 -0
  407. package/apps/web/.next/server/chunks/[turbopack]_runtime.js.map +11 -0
  408. package/apps/web/.next/server/chunks/apps_web__next-internal_server_app_favicon_ico_route_actions_0h5n1et.js +3 -0
  409. package/apps/web/.next/server/chunks/apps_web__next-internal_server_app_favicon_ico_route_actions_0h5n1et.js.map +1 -0
  410. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__00707zu._.js +3 -0
  411. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__00707zu._.js.map +1 -0
  412. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__02w1lqw._.js +33 -0
  413. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__02w1lqw._.js.map +1 -0
  414. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__058frv2._.js +3 -0
  415. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__058frv2._.js.map +1 -0
  416. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05mnfv7._.js +3 -0
  417. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05mnfv7._.js.map +1 -0
  418. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05w0js1._.js +3 -0
  419. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05w0js1._.js.map +1 -0
  420. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05y8~sf._.js +3 -0
  421. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__05y8~sf._.js.map +1 -0
  422. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0a~4k2j._.js +8 -0
  423. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0a~4k2j._.js.map +1 -0
  424. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0bzgqz2._.js +3 -0
  425. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0bzgqz2._.js.map +1 -0
  426. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0csq2e.._.js +3 -0
  427. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0csq2e.._.js.map +1 -0
  428. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0dgn1-d._.js +8 -0
  429. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0dgn1-d._.js.map +1 -0
  430. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g.z8rw._.js +3 -0
  431. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g.z8rw._.js.map +1 -0
  432. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g7.yrd._.js +3 -0
  433. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0g7.yrd._.js.map +1 -0
  434. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0ill7bp._.js +4 -0
  435. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0ill7bp._.js.map +1 -0
  436. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0lxs646._.js +33 -0
  437. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0lxs646._.js.map +1 -0
  438. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0osecwm._.js +3 -0
  439. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0osecwm._.js.map +1 -0
  440. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0x5.eah._.js +3 -0
  441. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__0x5.eah._.js.map +1 -0
  442. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10mg911._.js +9 -0
  443. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10mg911._.js.map +1 -0
  444. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10xopfz._.js +3 -0
  445. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__10xopfz._.js.map +1 -0
  446. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__11illgy._.js +3 -0
  447. package/apps/web/.next/server/chunks/ssr/[root-of-the-server]__11illgy._.js.map +1 -0
  448. package/apps/web/.next/server/chunks/ssr/[turbopack]_runtime.js +903 -0
  449. package/apps/web/.next/server/chunks/ssr/[turbopack]_runtime.js.map +11 -0
  450. package/apps/web/.next/server/chunks/ssr/_0hy8~s0._.js +6 -0
  451. package/apps/web/.next/server/chunks/ssr/_0hy8~s0._.js.map +1 -0
  452. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__global-error_page_actions_0.u5cfa.js +3 -0
  453. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__global-error_page_actions_0.u5cfa.js.map +1 -0
  454. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__not-found_page_actions_0appun9.js +3 -0
  455. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app__not-found_page_actions_0appun9.js.map +1 -0
  456. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_claude_page_actions_0_uv-yn.js +3 -0
  457. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_claude_page_actions_0_uv-yn.js.map +1 -0
  458. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_codex_page_actions_0ace7zi.js +3 -0
  459. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_codex_page_actions_0ace7zi.js.map +1 -0
  460. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_gemini_page_actions_0ux-r~z.js +3 -0
  461. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_gemini_page_actions_0ux-r~z.js.map +1 -0
  462. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_login_page_actions_0srfp5v.js +3 -0
  463. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_login_page_actions_0srfp5v.js.map +1 -0
  464. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_page_actions_0rm5_5w.js +3 -0
  465. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_page_actions_0rm5_5w.js.map +1 -0
  466. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_task_[id]_page_actions_0bd_3_p.js +3 -0
  467. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_task_[id]_page_actions_0bd_3_p.js.map +1 -0
  468. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_test_page_actions_0pn8asm.js +3 -0
  469. package/apps/web/.next/server/chunks/ssr/apps_web__next-internal_server_app_test_page_actions_0pn8asm.js.map +1 -0
  470. package/apps/web/.next/server/chunks/ssr/apps_web_src_0s6cw51._.js +8 -0
  471. package/apps/web/.next/server/chunks/ssr/apps_web_src_0s6cw51._.js.map +1 -0
  472. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_login_page_tsx_07oskhj._.js +3 -0
  473. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_login_page_tsx_07oskhj._.js.map +1 -0
  474. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_page_tsx_0kq.zh9._.js +3 -0
  475. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_page_tsx_0kq.zh9._.js.map +1 -0
  476. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_test_page_tsx_04ji_kt._.js +3 -0
  477. package/apps/web/.next/server/chunks/ssr/apps_web_src_app_test_page_tsx_04ji_kt._.js.map +1 -0
  478. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_02y94.o._.js +3 -0
  479. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_02y94.o._.js.map +1 -0
  480. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_0y6q6xu._.js +3 -0
  481. package/apps/web/.next/server/chunks/ssr/apps_web_src_features_0y6q6xu._.js.map +1 -0
  482. package/apps/web/.next/server/chunks/ssr/node_modules_09w7yel._.js +33 -0
  483. package/apps/web/.next/server/chunks/ssr/node_modules_09w7yel._.js.map +1 -0
  484. package/apps/web/.next/server/chunks/ssr/node_modules_0ck2~9g._.js +3 -0
  485. package/apps/web/.next/server/chunks/ssr/node_modules_0ck2~9g._.js.map +1 -0
  486. package/apps/web/.next/server/chunks/ssr/node_modules_0i2xw~e._.js +3 -0
  487. package/apps/web/.next/server/chunks/ssr/node_modules_0i2xw~e._.js.map +1 -0
  488. package/apps/web/.next/server/chunks/ssr/node_modules_0vtdjw7._.js +3 -0
  489. package/apps/web/.next/server/chunks/ssr/node_modules_0vtdjw7._.js.map +1 -0
  490. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_03nkrli._.js +19 -0
  491. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_03nkrli._.js.map +1 -0
  492. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_0h9llsw._.js +6 -0
  493. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_0h9llsw._.js.map +1 -0
  494. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js +3 -0
  495. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js.map +1 -0
  496. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js +3 -0
  497. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js.map +1 -0
  498. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js +3 -0
  499. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js.map +1 -0
  500. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js +3 -0
  501. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js.map +1 -0
  502. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_01s3o34.js +4 -0
  503. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_01s3o34.js.map +1 -0
  504. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ax1b3s.js +4 -0
  505. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ax1b3s.js.map +1 -0
  506. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0gl78zj.js +4 -0
  507. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0gl78zj.js.map +1 -0
  508. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0j~tyzr.js +4 -0
  509. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0j~tyzr.js.map +1 -0
  510. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0khf96-.js +4 -0
  511. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0khf96-.js.map +1 -0
  512. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qgz_85.js +4 -0
  513. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qgz_85.js.map +1 -0
  514. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0unh3f-.js +4 -0
  515. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0unh3f-.js.map +1 -0
  516. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0uq606i.js +4 -0
  517. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0uq606i.js.map +1 -0
  518. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_128e6.l.js +4 -0
  519. package/apps/web/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_128e6.l.js.map +1 -0
  520. package/apps/web/.next/server/functions-config-manifest.json +4 -0
  521. package/apps/web/.next/server/interception-route-rewrite-manifest.js +1 -0
  522. package/apps/web/.next/server/middleware-build-manifest.js +21 -0
  523. package/apps/web/.next/server/middleware-manifest.json +6 -0
  524. package/apps/web/.next/server/next-font-manifest.js +1 -0
  525. package/apps/web/.next/server/next-font-manifest.json +39 -0
  526. package/apps/web/.next/server/pages/404.html +1 -0
  527. package/apps/web/.next/server/pages/500.html +1 -0
  528. package/apps/web/.next/server/pages-manifest.json +4 -0
  529. package/apps/web/.next/server/prefetch-hints.json +1 -0
  530. package/apps/web/.next/server/server-reference-manifest.js +1 -0
  531. package/apps/web/.next/server/server-reference-manifest.json +5 -0
  532. package/apps/web/.next/static/chunks/01xlw8hd842-c.js +1 -0
  533. package/apps/web/.next/static/chunks/03~yq9q893hmn.js +1 -0
  534. package/apps/web/.next/static/chunks/04w-clkdzn_sn.js +6 -0
  535. package/apps/web/.next/static/chunks/066jf0nk75nic.css +2 -0
  536. package/apps/web/.next/static/chunks/0bmpc66o4m-9z.js +1 -0
  537. package/apps/web/.next/static/chunks/0cctfc2jrxq_0.js +1 -0
  538. package/apps/web/.next/static/chunks/0dk1ec~jpoxa3.css +1 -0
  539. package/apps/web/.next/static/chunks/0e992tq36rg-i.js +6 -0
  540. package/apps/web/.next/static/chunks/0ieuc6bs-l0iy.js +7 -0
  541. package/apps/web/.next/static/chunks/0nd5y.4d2gl8g.js +1 -0
  542. package/apps/web/.next/static/chunks/0o-t4yw-v8ahl.js +6 -0
  543. package/apps/web/.next/static/chunks/0pqt~8bl3ukh4.js +4 -0
  544. package/apps/web/.next/static/chunks/0rjn.~e6pvni1.js +2 -0
  545. package/apps/web/.next/static/chunks/0t2xr05rlu96l.js +1 -0
  546. package/apps/web/.next/static/chunks/0uuu-x.ka3jyt.js +1 -0
  547. package/apps/web/.next/static/chunks/0x15z029u118o.js +1 -0
  548. package/apps/web/.next/static/chunks/0~.kxojjn0k1x.js +1 -0
  549. package/apps/web/.next/static/chunks/10t1c-qsk.cdw.js +1 -0
  550. package/apps/web/.next/static/chunks/14zwv8duu059g.js +31 -0
  551. package/apps/web/.next/static/chunks/turbopack-0gpa2pyrgntw-.js +1 -0
  552. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_buildManifest.js +11 -0
  553. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_clientMiddlewareManifest.js +1 -0
  554. package/apps/web/.next/static/fdXuROcW6IkgkI61bg3UM/_ssgManifest.js +1 -0
  555. package/apps/web/.next/static/media/4fa387ec64143e14-s.0wkzw~je483f-.woff2 +0 -0
  556. package/apps/web/.next/static/media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2 +0 -0
  557. package/apps/web/.next/static/media/5ce348bf30bf5439-s.0zgw-jeven.3w.woff2 +0 -0
  558. package/apps/web/.next/static/media/6306c77e7c8268e4-s.0rhz0arwfsn~5.woff2 +0 -0
  559. package/apps/web/.next/static/media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2 +0 -0
  560. package/apps/web/.next/static/media/797e433ab948586e-s.p.08e28id.o-okb.woff2 +0 -0
  561. package/apps/web/.next/static/media/7d817b4c03b0c5f1-s.0l76wvqk9d84w.woff2 +0 -0
  562. package/apps/web/.next/static/media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2 +0 -0
  563. package/apps/web/.next/static/media/bbc41e54d2fcbd21-s.0k4k9394f2q-k.woff2 +0 -0
  564. package/apps/web/.next/static/media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2 +0 -0
  565. package/apps/web/.next/static/media/favicon.0x3dzn~oxb6tn.ico +0 -0
  566. package/apps/web/.next/static/media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2 +0 -0
  567. package/apps/web/.next/trace +1 -0
  568. package/apps/web/.next/trace-build +1 -0
  569. package/apps/web/.next/turbopack +0 -0
  570. package/apps/web/.next/types/cache-life.d.ts +145 -0
  571. package/apps/web/.next/types/routes.d.ts +63 -0
  572. package/apps/web/.next/types/validator.ts +115 -0
  573. package/package.json +28 -42
  574. package/packages/cli/dist/commands/init.d.ts +1 -2
  575. package/packages/cli/dist/commands/init.js +14 -16
  576. package/packages/cli/dist/commands/start.js +41 -26
  577. package/packages/cli/dist/index.js +6 -23
  578. package/packages/cli/dist/utils/package-root.d.ts +3 -0
  579. package/packages/cli/dist/utils/package-root.js +62 -0
  580. package/.gitignore +0 -23
  581. package/.npmignore +0 -21
  582. package/.prettierignore +0 -6
  583. package/.prettierrc +0 -26
  584. package/AGENTS.md +0 -10
  585. package/CLAUDE.md +0 -10
  586. package/apps/server/eslint.config.mjs +0 -20
  587. package/apps/server/nest-cli.json +0 -8
  588. package/apps/server/package.json +0 -89
  589. package/apps/server/scripts/postinstall.js +0 -53
  590. package/apps/server/src/__mocks__/glob.js +0 -6
  591. package/apps/server/src/__mocks__/uuid.js +0 -5
  592. package/apps/server/src/app.controller.spec.ts +0 -24
  593. package/apps/server/src/app.controller.ts +0 -13
  594. package/apps/server/src/app.module.ts +0 -18
  595. package/apps/server/src/app.service.ts +0 -8
  596. package/apps/server/src/common/ji-paths.ts +0 -41
  597. package/apps/server/src/database/database.module.ts +0 -27
  598. package/apps/server/src/database/entities/agent-changelog.entity.ts +0 -39
  599. package/apps/server/src/database/entities/agent-session.entity.ts +0 -29
  600. package/apps/server/src/database/entities/conversation.entity.ts +0 -41
  601. package/apps/server/src/database/entities/session.entity.ts +0 -16
  602. package/apps/server/src/database/entities/task-agent-run.entity.ts +0 -40
  603. package/apps/server/src/database/entities/task-agent.entity.ts +0 -42
  604. package/apps/server/src/database/entities/task-requirement.entity.ts +0 -27
  605. package/apps/server/src/database/entities/task-run.entity.ts +0 -41
  606. package/apps/server/src/database/entities/task.entity.ts +0 -44
  607. package/apps/server/src/main.ts +0 -65
  608. package/apps/server/src/modules/agents/agent-model-settings.spec.ts +0 -80
  609. package/apps/server/src/modules/agents/agents.module.ts +0 -11
  610. package/apps/server/src/modules/agents/claude/claude-auth.manager.ts +0 -83
  611. package/apps/server/src/modules/agents/claude/claude-pty.manager.ts +0 -380
  612. package/apps/server/src/modules/agents/claude/claude.controller.ts +0 -85
  613. package/apps/server/src/modules/agents/claude/claude.gateway.ts +0 -158
  614. package/apps/server/src/modules/agents/claude/claude.module.ts +0 -18
  615. package/apps/server/src/modules/agents/claude/claude.service.ts +0 -67
  616. package/apps/server/src/modules/agents/claude/dto/create-session.dto.ts +0 -24
  617. package/apps/server/src/modules/agents/claude/dto/resize-session.dto.ts +0 -13
  618. package/apps/server/src/modules/agents/claude/dto/send-input.dto.ts +0 -9
  619. package/apps/server/src/modules/agents/claude/interfaces/claude-session.interface.ts +0 -26
  620. package/apps/server/src/modules/agents/claude/interfaces/pty-event.interface.ts +0 -10
  621. package/apps/server/src/modules/agents/claude/interfaces/stream-event.interface.ts +0 -61
  622. package/apps/server/src/modules/agents/codex/codex-auth.manager.ts +0 -107
  623. package/apps/server/src/modules/agents/codex/codex-session.manager.ts +0 -357
  624. package/apps/server/src/modules/agents/codex/codex.controller.ts +0 -64
  625. package/apps/server/src/modules/agents/codex/codex.gateway.ts +0 -97
  626. package/apps/server/src/modules/agents/codex/codex.module.ts +0 -17
  627. package/apps/server/src/modules/agents/codex/dto/configure-auth.dto.ts +0 -7
  628. package/apps/server/src/modules/agents/gemini/dto/configure-auth.dto.ts +0 -15
  629. package/apps/server/src/modules/agents/gemini/dto/create-session.dto.ts +0 -9
  630. package/apps/server/src/modules/agents/gemini/dto/send-input.dto.ts +0 -9
  631. package/apps/server/src/modules/agents/gemini/gemini-auth.manager.ts +0 -157
  632. package/apps/server/src/modules/agents/gemini/gemini-session.manager.ts +0 -287
  633. package/apps/server/src/modules/agents/gemini/gemini.controller.ts +0 -93
  634. package/apps/server/src/modules/agents/gemini/gemini.gateway.ts +0 -149
  635. package/apps/server/src/modules/agents/gemini/gemini.module.ts +0 -17
  636. package/apps/server/src/modules/agents/gemini/interfaces/gemini-session.interface.ts +0 -18
  637. package/apps/server/src/modules/agents/gemini/interfaces/stream-event.interface.ts +0 -14
  638. package/apps/server/src/modules/agents/session-termination.spec.ts +0 -103
  639. package/apps/server/src/modules/changelog/changelog.controller.ts +0 -20
  640. package/apps/server/src/modules/changelog/changelog.module.ts +0 -14
  641. package/apps/server/src/modules/changelog/changelog.service.spec.ts +0 -531
  642. package/apps/server/src/modules/changelog/changelog.service.ts +0 -690
  643. package/apps/server/src/modules/conversations/conversation.controller.spec.ts +0 -106
  644. package/apps/server/src/modules/conversations/conversation.controller.ts +0 -60
  645. package/apps/server/src/modules/conversations/conversation.module.ts +0 -14
  646. package/apps/server/src/modules/conversations/conversation.service.spec.ts +0 -176
  647. package/apps/server/src/modules/conversations/conversation.service.ts +0 -54
  648. package/apps/server/src/modules/conversations/dto/create-conversation.dto.ts +0 -37
  649. package/apps/server/src/modules/conversations/enums/conversation.enum.ts +0 -13
  650. package/apps/server/src/modules/fs/fs.controller.ts +0 -29
  651. package/apps/server/src/modules/fs/fs.module.ts +0 -8
  652. package/apps/server/src/modules/harness/dto/save-harness.dto.ts +0 -9
  653. package/apps/server/src/modules/harness/harness.controller.spec.ts +0 -95
  654. package/apps/server/src/modules/harness/harness.controller.ts +0 -35
  655. package/apps/server/src/modules/harness/harness.module.ts +0 -11
  656. package/apps/server/src/modules/harness/harness.service.spec.ts +0 -217
  657. package/apps/server/src/modules/harness/harness.service.ts +0 -112
  658. package/apps/server/src/modules/sessions/session.controller.spec.ts +0 -68
  659. package/apps/server/src/modules/sessions/session.controller.ts +0 -43
  660. package/apps/server/src/modules/sessions/session.module.ts +0 -14
  661. package/apps/server/src/modules/sessions/session.service.spec.ts +0 -106
  662. package/apps/server/src/modules/sessions/session.service.ts +0 -35
  663. package/apps/server/src/modules/tasks/dto/create-task.dto.ts +0 -54
  664. package/apps/server/src/modules/tasks/dto/execute-task.dto.ts +0 -22
  665. package/apps/server/src/modules/tasks/dto/merge-file.dto.ts +0 -7
  666. package/apps/server/src/modules/tasks/dto/rerun-task.dto.ts +0 -14
  667. package/apps/server/src/modules/tasks/dto/update-task.dto.ts +0 -55
  668. package/apps/server/src/modules/tasks/task-execution.service.ts +0 -978
  669. package/apps/server/src/modules/tasks/task.gateway.ts +0 -140
  670. package/apps/server/src/modules/tasks/tasks.controller.spec.ts +0 -210
  671. package/apps/server/src/modules/tasks/tasks.controller.ts +0 -139
  672. package/apps/server/src/modules/tasks/tasks.module.ts +0 -30
  673. package/apps/server/src/modules/tasks/tasks.service.spec.ts +0 -552
  674. package/apps/server/src/modules/tasks/tasks.service.ts +0 -333
  675. package/apps/server/test/app.e2e-spec.ts +0 -28
  676. package/apps/server/test/jest-e2e.json +0 -9
  677. package/apps/server/tsconfig.build.json +0 -4
  678. package/apps/server/tsconfig.json +0 -13
  679. package/apps/web/AGENTS.md +0 -7
  680. package/apps/web/CLAUDE.md +0 -1
  681. package/apps/web/eslint.config.mjs +0 -21
  682. package/apps/web/next-env.d.ts +0 -6
  683. package/apps/web/postcss.config.mjs +0 -7
  684. package/apps/web/src/app/claude/page.tsx +0 -5
  685. package/apps/web/src/app/codex/page.tsx +0 -126
  686. package/apps/web/src/app/gemini/page.tsx +0 -130
  687. package/apps/web/src/app/globals.css +0 -149
  688. package/apps/web/src/app/layout.tsx +0 -40
  689. package/apps/web/src/app/login/page.tsx +0 -67
  690. package/apps/web/src/app/page.tsx +0 -497
  691. package/apps/web/src/app/task/[id]/page.tsx +0 -11
  692. package/apps/web/src/app/test/page.tsx +0 -298
  693. package/apps/web/src/components/ui/Modal.tsx +0 -78
  694. package/apps/web/src/components/ui/WorkingDirPicker.tsx +0 -195
  695. package/apps/web/src/components/ui/__tests__/Modal.test.tsx +0 -68
  696. package/apps/web/src/features/auth/api/__tests__/auth.api.test.ts +0 -83
  697. package/apps/web/src/features/auth/api/auth.api.ts +0 -81
  698. package/apps/web/src/features/auth/hooks/__tests__/useClaudeAuth.test.ts +0 -166
  699. package/apps/web/src/features/auth/hooks/__tests__/useCodexAuth.test.ts +0 -127
  700. package/apps/web/src/features/auth/hooks/__tests__/useGeminiAuth.test.ts +0 -120
  701. package/apps/web/src/features/auth/hooks/useClaudeAuth.ts +0 -88
  702. package/apps/web/src/features/auth/hooks/useCodexAuth.ts +0 -149
  703. package/apps/web/src/features/auth/hooks/useGeminiAuth.ts +0 -125
  704. package/apps/web/src/features/auth/ui/CodexLoginPanel.tsx +0 -302
  705. package/apps/web/src/features/auth/ui/GeminiLoginPanel.tsx +0 -316
  706. package/apps/web/src/features/auth/ui/LoginForm.tsx +0 -190
  707. package/apps/web/src/features/auth/ui/LoginPanel.tsx +0 -114
  708. package/apps/web/src/features/auth/ui/__tests__/LoginPanel.test.tsx +0 -105
  709. package/apps/web/src/features/chat/api/__tests__/sessions.api.test.ts +0 -187
  710. package/apps/web/src/features/chat/api/sessions.api.ts +0 -161
  711. package/apps/web/src/features/chat/container/ClaudePageContainer.tsx +0 -152
  712. package/apps/web/src/features/chat/hooks/__tests__/useCodexSessions.test.ts +0 -131
  713. package/apps/web/src/features/chat/hooks/__tests__/useGeminiSessions.test.ts +0 -130
  714. package/apps/web/src/features/chat/hooks/useAgentModelSettings.ts +0 -54
  715. package/apps/web/src/features/chat/hooks/useClaudeSessions.ts +0 -323
  716. package/apps/web/src/features/chat/hooks/useCodexSessions.ts +0 -275
  717. package/apps/web/src/features/chat/hooks/useGeminiSessions.ts +0 -255
  718. package/apps/web/src/features/chat/hooks/useSessionCommand.ts +0 -66
  719. package/apps/web/src/features/chat/hooks/useSessionRename.ts +0 -61
  720. package/apps/web/src/features/chat/hooks/useSessionWorkingDirectories.ts +0 -34
  721. package/apps/web/src/features/chat/hooks/useUnifiedSessions.ts +0 -156
  722. package/apps/web/src/features/chat/lib/agentModelOptions.ts +0 -72
  723. package/apps/web/src/features/chat/ui/AgentModelPicker.tsx +0 -134
  724. package/apps/web/src/features/chat/ui/AgentSelectModal.tsx +0 -236
  725. package/apps/web/src/features/chat/ui/ChatInput.tsx +0 -162
  726. package/apps/web/src/features/chat/ui/ChatMessage.tsx +0 -204
  727. package/apps/web/src/features/chat/ui/ChatWorkspace.tsx +0 -207
  728. package/apps/web/src/features/chat/ui/CheckingSkeleton.tsx +0 -44
  729. package/apps/web/src/features/chat/ui/ClaudeLoginView.tsx +0 -44
  730. package/apps/web/src/features/chat/ui/PermissionCard.tsx +0 -37
  731. package/apps/web/src/features/chat/ui/SessionSidebar.tsx +0 -280
  732. package/apps/web/src/features/chat/ui/__tests__/AgentSelectModal.test.tsx +0 -58
  733. package/apps/web/src/features/chat/ui/__tests__/ChatInput.test.tsx +0 -134
  734. package/apps/web/src/features/chat/ui/__tests__/ChatMessage.test.tsx +0 -106
  735. package/apps/web/src/features/chat/ui/__tests__/ChatWorkspace.test.tsx +0 -66
  736. package/apps/web/src/features/diff/ui/DiffFileRow.tsx +0 -73
  737. package/apps/web/src/features/diff/ui/DiffHunk.tsx +0 -61
  738. package/apps/web/src/features/diff/ui/FileChangeBadge.tsx +0 -23
  739. package/apps/web/src/features/diff/ui/__tests__/DiffFileRow.test.tsx +0 -40
  740. package/apps/web/src/features/diff/ui/__tests__/DiffHunk.test.tsx +0 -24
  741. package/apps/web/src/features/diff/ui/__tests__/FileChangeBadge.test.tsx +0 -16
  742. package/apps/web/src/features/fs/api/fs.api.ts +0 -14
  743. package/apps/web/src/features/fs/hooks/useDirBrowser.ts +0 -50
  744. package/apps/web/src/features/harness/api/__tests__/harness.api.test.ts +0 -73
  745. package/apps/web/src/features/harness/api/harness.api.ts +0 -46
  746. package/apps/web/src/features/harness/hooks/__tests__/useHarness.test.ts +0 -65
  747. package/apps/web/src/features/harness/hooks/useHarness.ts +0 -66
  748. package/apps/web/src/features/harness/ui/HarnessModal.tsx +0 -171
  749. package/apps/web/src/features/harness/ui/__tests__/HarnessModal.test.tsx +0 -46
  750. package/apps/web/src/features/status/ui/AgentStatusModal.tsx +0 -267
  751. package/apps/web/src/features/status/ui/__tests__/AgentStatusModal.test.tsx +0 -71
  752. package/apps/web/src/features/tasks/api/__tests__/changelog.api.test.ts +0 -89
  753. package/apps/web/src/features/tasks/api/__tests__/tasks.api.test.ts +0 -282
  754. package/apps/web/src/features/tasks/api/changelog.api.ts +0 -52
  755. package/apps/web/src/features/tasks/api/tasks.api.ts +0 -175
  756. package/apps/web/src/features/tasks/container/TaskDetailPageContainer.tsx +0 -69
  757. package/apps/web/src/features/tasks/hooks/__tests__/useChangelogCodeCopy.test.ts +0 -48
  758. package/apps/web/src/features/tasks/hooks/__tests__/useTaskChangelog.test.ts +0 -48
  759. package/apps/web/src/features/tasks/hooks/__tests__/useTaskCreate.test.ts +0 -217
  760. package/apps/web/src/features/tasks/hooks/__tests__/useTaskEdit.test.ts +0 -152
  761. package/apps/web/src/features/tasks/hooks/__tests__/useTaskExecution.test.ts +0 -143
  762. package/apps/web/src/features/tasks/hooks/__tests__/useTaskList.test.ts +0 -168
  763. package/apps/web/src/features/tasks/hooks/__tests__/useTaskNotification.test.ts +0 -125
  764. package/apps/web/src/features/tasks/hooks/__tests__/useTaskRuns.test.ts +0 -51
  765. package/apps/web/src/features/tasks/hooks/useChangelogCodeCopy.ts +0 -52
  766. package/apps/web/src/features/tasks/hooks/useCopyToClipboard.ts +0 -47
  767. package/apps/web/src/features/tasks/hooks/useTaskChangelog.ts +0 -32
  768. package/apps/web/src/features/tasks/hooks/useTaskCreate.ts +0 -137
  769. package/apps/web/src/features/tasks/hooks/useTaskDetail.ts +0 -217
  770. package/apps/web/src/features/tasks/hooks/useTaskEdit.ts +0 -130
  771. package/apps/web/src/features/tasks/hooks/useTaskExecution.ts +0 -137
  772. package/apps/web/src/features/tasks/hooks/useTaskList.ts +0 -159
  773. package/apps/web/src/features/tasks/hooks/useTaskNotification.ts +0 -80
  774. package/apps/web/src/features/tasks/hooks/useTaskRuns.ts +0 -32
  775. package/apps/web/src/features/tasks/ui/AgentOutputPanel.tsx +0 -203
  776. package/apps/web/src/features/tasks/ui/AgentRoleSelect.tsx +0 -97
  777. package/apps/web/src/features/tasks/ui/ChangelogPanel.tsx +0 -321
  778. package/apps/web/src/features/tasks/ui/RunHistoryPanel.tsx +0 -193
  779. package/apps/web/src/features/tasks/ui/TaskCreateModal.tsx +0 -205
  780. package/apps/web/src/features/tasks/ui/TaskDetailView.tsx +0 -413
  781. package/apps/web/src/features/tasks/ui/TaskEditModal.tsx +0 -165
  782. package/apps/web/src/features/tasks/ui/TaskListModal.tsx +0 -591
  783. package/apps/web/src/features/tasks/ui/__tests__/AgentRoleSelect.test.tsx +0 -91
  784. package/apps/web/src/features/tasks/ui/__tests__/ChangelogPanel.test.tsx +0 -94
  785. package/apps/web/src/features/tasks/ui/__tests__/RunHistoryPanel.test.tsx +0 -71
  786. package/apps/web/src/features/tasks/ui/__tests__/TaskCreateModal.test.tsx +0 -153
  787. package/apps/web/src/features/tasks/ui/__tests__/TaskEditModal.test.tsx +0 -75
  788. package/apps/web/src/features/tasks/ui/__tests__/TaskListModal.test.tsx +0 -243
  789. package/apps/web/src/hooks/useWorkingDir.ts +0 -28
  790. package/apps/web/src/lib/__tests__/ansi.test.ts +0 -88
  791. package/apps/web/src/lib/ansi.ts +0 -105
  792. package/apps/web/src/lib/constants.ts +0 -4
  793. package/apps/web/src/lib/quota.ts +0 -22
  794. package/apps/web/src/lib/theme.tsx +0 -78
  795. package/apps/web/src/lib/toast.tsx +0 -175
  796. package/apps/web/src/store/agentStatusStore.ts +0 -38
  797. package/apps/web/tsconfig.json +0 -18
  798. package/apps/web/vitest.config.ts +0 -25
  799. package/apps/web/vitest.setup.ts +0 -10
  800. package/packages/cli/dist/utils/project-init.d.ts +0 -12
  801. package/packages/cli/dist/utils/project-init.js +0 -258
  802. package/packages/cli/package.json +0 -30
  803. package/packages/cli/src/commands/check.ts +0 -77
  804. package/packages/cli/src/commands/init.ts +0 -209
  805. package/packages/cli/src/commands/start.ts +0 -183
  806. package/packages/cli/src/index.ts +0 -91
  807. package/packages/cli/src/utils/agent-tools.ts +0 -201
  808. package/packages/cli/src/utils/project-init.ts +0 -252
  809. package/packages/cli/src/utils/proxy.ts +0 -123
  810. package/packages/cli/tsconfig.json +0 -14
  811. package/packages/eslint-config/base.mjs +0 -31
  812. package/packages/eslint-config/nest.mjs +0 -55
  813. package/packages/eslint-config/next.mjs +0 -23
  814. package/packages/eslint-config/package.json +0 -20
  815. package/packages/typescript-config/base.json +0 -16
  816. package/packages/typescript-config/nestjs.json +0 -17
  817. package/packages/typescript-config/nextjs.json +0 -15
  818. package/packages/typescript-config/package.json +0 -11
  819. package/turbo.json +0 -28
  820. /package/apps/web/{src/app/favicon.ico → .next/server/app/favicon.ico.body} +0 -0
@@ -1,552 +0,0 @@
1
- import * as fs from 'fs';
2
-
3
- import { BadRequestException, NotFoundException } from '@nestjs/common';
4
- import { Test, TestingModule } from '@nestjs/testing';
5
- import { getRepositoryToken } from '@nestjs/typeorm';
6
-
7
- import { TaskAgentRunEntity } from '../../database/entities/task-agent-run.entity';
8
- import { TaskAgentEntity } from '../../database/entities/task-agent.entity';
9
- import { TaskRequirementEntity } from '../../database/entities/task-requirement.entity';
10
- import { TaskRunEntity } from '../../database/entities/task-run.entity';
11
- import { TaskEntity } from '../../database/entities/task.entity';
12
- import { GitChangelogService } from '../changelog/changelog.service';
13
- import { TasksService } from './tasks.service';
14
-
15
- // task-execution.service는 node-pty / spawn 등 외부 프로세스에 의존하므로 전체 모킹
16
- jest.mock('./task-execution.service', () => ({
17
- TaskExecutionService: class MockTaskExecutionService {
18
- spawnTask = jest.fn().mockResolvedValue(undefined);
19
- stopTask = jest.fn().mockResolvedValue(undefined);
20
- },
21
- }));
22
-
23
- // changelog.service는 git CLI에 의존하므로 전체 모킹
24
- jest.mock('../changelog/changelog.service', () => ({
25
- GitChangelogService: class MockGitChangelogService {
26
- mergeAll = jest.fn().mockReturnValue({ success: true, message: '전체 병합이 완료되었습니다.' });
27
- mergeFile = jest.fn().mockReturnValue({ success: true, message: 'file.ts 병합이 완료되었습니다.' });
28
- mergeAllFromChangelog = jest.fn().mockResolvedValue({ success: false, message: 'No stored changelog patch exists for this agent.' });
29
- mergeFileFromChangelog = jest.fn().mockResolvedValue({ success: false, message: 'No stored changelog patch exists for this file.' });
30
- getByTask = jest.fn().mockResolvedValue([
31
- { agentId: 1, files: [{ id: 1, filePath: 'src/app.ts', changeType: 'modified', additions: 1, deletions: 0, patch: null }] },
32
- ]);
33
- },
34
- }));
35
-
36
- // eslint-disable-next-line @typescript-eslint/no-require-imports
37
- const { TaskExecutionService } = require('./task-execution.service');
38
-
39
- jest.mock('fs', () => ({
40
- existsSync: jest.fn(),
41
- statSync: jest.fn(),
42
- }));
43
-
44
- const mockRepo = () => ({
45
- create: jest.fn((dto: any) => ({ ...dto })),
46
- save: jest.fn((e: any) => Promise.resolve(e)),
47
- findOne: jest.fn(),
48
- find: jest.fn(),
49
- update: jest.fn().mockResolvedValue({}),
50
- delete: jest.fn().mockResolvedValue({}),
51
- });
52
-
53
- describe('TasksService', () => {
54
- let service: TasksService;
55
- let taskRepo: ReturnType<typeof mockRepo>;
56
- let requirementRepo: ReturnType<typeof mockRepo>;
57
- let agentRepo: ReturnType<typeof mockRepo>;
58
- let runRepo: ReturnType<typeof mockRepo>;
59
- let executionService: { spawnTask: jest.Mock; stopTask: jest.Mock };
60
- let gitChangelogService: {
61
- mergeAll: jest.Mock;
62
- mergeFile: jest.Mock;
63
- mergeAllFromChangelog: jest.Mock;
64
- mergeFileFromChangelog: jest.Mock;
65
- getByTask: jest.Mock;
66
- };
67
-
68
- const baseTask: TaskEntity = {
69
- id: 'task-1',
70
- title: 'Test Task',
71
- status: 'pending',
72
- workingDir: '/tmp/project',
73
- claudeSessionId: null,
74
- archived: false,
75
- createdAt: new Date('2024-01-01'),
76
- updatedAt: new Date('2024-01-01'),
77
- requirements: [],
78
- agents: [],
79
- };
80
-
81
- const baseAgent: TaskAgentEntity = {
82
- id: 1,
83
- taskId: 'task-1',
84
- task: baseTask,
85
- agentType: 'claude',
86
- role: 'backend',
87
- customRole: null,
88
- claudeSessionId: null,
89
- worktreePath: '/tmp/worktrees/agent-1',
90
- startCommitHash: 'abc123',
91
- status: 'pending',
92
- createdAt: new Date('2024-01-01'),
93
- };
94
-
95
- beforeEach(async () => {
96
- const module: TestingModule = await Test.createTestingModule({
97
- providers: [
98
- TasksService,
99
- { provide: getRepositoryToken(TaskEntity), useFactory: mockRepo },
100
- { provide: getRepositoryToken(TaskRequirementEntity), useFactory: mockRepo },
101
- { provide: getRepositoryToken(TaskAgentEntity), useFactory: mockRepo },
102
- { provide: getRepositoryToken(TaskRunEntity), useFactory: mockRepo },
103
- { provide: getRepositoryToken(TaskAgentRunEntity), useFactory: mockRepo },
104
- { provide: TaskExecutionService, useClass: TaskExecutionService },
105
- { provide: GitChangelogService, useClass: GitChangelogService },
106
- ],
107
- }).compile();
108
-
109
- service = module.get(TasksService);
110
- taskRepo = module.get(getRepositoryToken(TaskEntity));
111
- requirementRepo = module.get(getRepositoryToken(TaskRequirementEntity));
112
- agentRepo = module.get(getRepositoryToken(TaskAgentEntity));
113
- runRepo = module.get(getRepositoryToken(TaskRunEntity));
114
- executionService = module.get(TaskExecutionService) as any;
115
- gitChangelogService = module.get(GitChangelogService) as any;
116
- });
117
-
118
- afterEach(() => jest.clearAllMocks());
119
-
120
- const mockDirectory = () => {
121
- (fs.existsSync as jest.Mock).mockReturnValue(true);
122
- (fs.statSync as jest.Mock).mockReturnValue({ isDirectory: () => true });
123
- };
124
-
125
- // ─── findOne ─────────────────────────────────────────────────────────────
126
-
127
- describe('findOne', () => {
128
- it('task를 반환한다', async () => {
129
- taskRepo.findOne.mockResolvedValue(baseTask);
130
- const result = await service.findOne('task-1');
131
- expect(result).toBe(baseTask);
132
- expect(taskRepo.findOne).toHaveBeenCalledWith({ where: { id: 'task-1' }, relations: ['requirements', 'agents'] });
133
- });
134
-
135
- it('task가 없으면 NotFoundException을 던진다', async () => {
136
- taskRepo.findOne.mockResolvedValue(null);
137
- await expect(service.findOne('not-exist')).rejects.toThrow(NotFoundException);
138
- });
139
- });
140
-
141
- // ─── findAll ─────────────────────────────────────────────────────────────
142
-
143
- describe('findAll', () => {
144
- it('아카이브되지 않은 task 목록을 반환한다', async () => {
145
- taskRepo.find.mockResolvedValue([baseTask]);
146
- const result = await service.findAll();
147
- expect(result).toEqual([baseTask]);
148
- expect(taskRepo.find).toHaveBeenCalledWith({
149
- where: { archived: false },
150
- relations: ['requirements', 'agents'],
151
- order: { createdAt: 'DESC' },
152
- });
153
- });
154
- });
155
-
156
- // ─── create ──────────────────────────────────────────────────────────────
157
-
158
- describe('create', () => {
159
- it('요구사항과 에이전트 없이 task를 생성한다', async () => {
160
- taskRepo.findOne.mockResolvedValue(baseTask);
161
-
162
- const result = await service.create({ title: 'Test Task' });
163
-
164
- expect(taskRepo.create).toHaveBeenCalled();
165
- expect(taskRepo.save).toHaveBeenCalled();
166
- expect(requirementRepo.save).not.toHaveBeenCalled();
167
- expect(agentRepo.save).not.toHaveBeenCalled();
168
- expect(result).toBe(baseTask);
169
- });
170
-
171
- it('요구사항 목록과 함께 task를 생성한다', async () => {
172
- taskRepo.findOne.mockResolvedValue(baseTask);
173
-
174
- await service.create({
175
- title: 'Task with requirements',
176
- requirements: [{ content: 'req-1' }, { content: 'req-2', orderIndex: 1 }],
177
- });
178
-
179
- expect(requirementRepo.save).toHaveBeenCalledTimes(1);
180
- const savedReqs = (requirementRepo.save as jest.Mock).mock.calls[0][0];
181
- expect(savedReqs).toHaveLength(2);
182
- expect(savedReqs[0].content).toBe('req-1');
183
- expect(savedReqs[0].orderIndex).toBe(0);
184
- expect(savedReqs[1].content).toBe('req-2');
185
- expect(savedReqs[1].orderIndex).toBe(1);
186
- });
187
-
188
- it('에이전트 목록과 함께 task를 생성한다', async () => {
189
- taskRepo.findOne.mockResolvedValue(baseTask);
190
-
191
- await service.create({
192
- title: 'Task with agents',
193
- agents: [{ role: 'backend', agentType: 'claude' }, { role: 'frontend' }],
194
- });
195
-
196
- expect(agentRepo.save).toHaveBeenCalledTimes(1);
197
- const savedAgents = (agentRepo.save as jest.Mock).mock.calls[0][0];
198
- expect(savedAgents).toHaveLength(2);
199
- expect(savedAgents[0].agentType).toBe('claude');
200
- expect(savedAgents[1].agentType).toBe('claude'); // default
201
- });
202
-
203
- it('workingDir을 null로 설정할 수 있다', async () => {
204
- taskRepo.findOne.mockResolvedValue({ ...baseTask, workingDir: null });
205
-
206
- await service.create({ title: 'No Dir Task' });
207
-
208
- const created = (taskRepo.create as jest.Mock).mock.calls[0][0];
209
- expect(created.workingDir).toBeNull();
210
- });
211
- });
212
-
213
- // ─── update ──────────────────────────────────────────────────────────────
214
-
215
- describe('update', () => {
216
- it('title을 업데이트한다', async () => {
217
- taskRepo.findOne.mockResolvedValue({ ...baseTask });
218
-
219
- await service.update('task-1', { title: 'New Title' });
220
-
221
- expect(taskRepo.save).toHaveBeenCalled();
222
- });
223
-
224
- it('요구사항을 교체한다', async () => {
225
- taskRepo.findOne.mockResolvedValue({ ...baseTask });
226
-
227
- await service.update('task-1', {
228
- requirements: [{ content: 'new-req' }],
229
- });
230
-
231
- expect(requirementRepo.delete).toHaveBeenCalledWith({ taskId: 'task-1' });
232
- expect(requirementRepo.save).toHaveBeenCalled();
233
- });
234
-
235
- it('빈 요구사항 배열로 모두 삭제한다', async () => {
236
- taskRepo.findOne.mockResolvedValue({ ...baseTask });
237
-
238
- await service.update('task-1', { requirements: [] });
239
-
240
- expect(requirementRepo.delete).toHaveBeenCalledWith({ taskId: 'task-1' });
241
- expect(requirementRepo.save).not.toHaveBeenCalled();
242
- });
243
-
244
- it('에이전트를 교체한다', async () => {
245
- taskRepo.findOne.mockResolvedValue({ ...baseTask });
246
-
247
- await service.update('task-1', {
248
- agents: [{ role: 'frontend', agentType: 'gemini' }],
249
- });
250
-
251
- expect(agentRepo.delete).toHaveBeenCalledWith({ taskId: 'task-1' });
252
- expect(agentRepo.save).toHaveBeenCalled();
253
- });
254
-
255
- it('task가 없으면 NotFoundException을 던진다', async () => {
256
- taskRepo.findOne.mockResolvedValue(null);
257
- await expect(service.update('not-exist', { title: 'X' })).rejects.toThrow(NotFoundException);
258
- });
259
- });
260
-
261
- // ─── execute ─────────────────────────────────────────────────────────────
262
-
263
- describe('execute', () => {
264
- it('task를 실행하고 spawnTask를 호출한다', async () => {
265
- const pendingTask = { ...baseTask, status: 'pending' };
266
- taskRepo.findOne.mockResolvedValue(pendingTask);
267
- runRepo.findOne.mockResolvedValue(null);
268
- const mockRun = { id: 1, taskId: 'task-1', version: 1, status: 'running' };
269
- runRepo.save.mockResolvedValue(mockRun);
270
-
271
- await service.execute('task-1', [{ agentId: 1, writeTestCode: true }]);
272
-
273
- expect(executionService.spawnTask).toHaveBeenCalledWith(pendingTask, undefined, mockRun.id, { testCodeAgentIds: [1] });
274
- });
275
-
276
- it('이전 실행 기록이 있으면 다음 버전으로 실행한다', async () => {
277
- const stoppedTask = { ...baseTask, status: 'stopped', agents: [baseAgent] };
278
- taskRepo.findOne
279
- .mockResolvedValueOnce(stoppedTask)
280
- .mockResolvedValueOnce({ ...stoppedTask, status: 'pending' })
281
- .mockResolvedValueOnce({ ...stoppedTask, status: 'running' });
282
- runRepo.findOne.mockResolvedValue({ version: 2 });
283
- runRepo.save.mockResolvedValue({ id: 3, taskId: 'task-1', version: 3, status: 'running' });
284
-
285
- await service.execute('task-1');
286
-
287
- expect(agentRepo.update).toHaveBeenCalledWith(baseAgent.id, { status: 'pending', claudeSessionId: null });
288
- expect(runRepo.create).toHaveBeenCalledWith({
289
- taskId: 'task-1',
290
- version: 3,
291
- supplementNote: null,
292
- status: 'running',
293
- });
294
- });
295
-
296
- it('이미 running 상태이면 spawnTask를 호출하지 않는다', async () => {
297
- taskRepo.findOne.mockResolvedValue({ ...baseTask, status: 'running' });
298
-
299
- await service.execute('task-1');
300
-
301
- expect(executionService.spawnTask).not.toHaveBeenCalled();
302
- });
303
- });
304
-
305
- // ─── rerun ────────────────────────────────────────────────────────────────
306
-
307
- describe('rerun', () => {
308
- it('에이전트 상태를 초기화하고 다음 버전으로 재실행한다', async () => {
309
- const taskWithAgents = { ...baseTask, agents: [baseAgent] };
310
- taskRepo.findOne.mockResolvedValue(taskWithAgents);
311
- runRepo.findOne.mockResolvedValue({ version: 2 });
312
- const mockRun = { id: 2, taskId: 'task-1', version: 3, status: 'running' };
313
- runRepo.save.mockResolvedValue(mockRun);
314
-
315
- await service.rerun('task-1', '보완 메모');
316
-
317
- expect(agentRepo.update).toHaveBeenCalledWith(baseAgent.id, { status: 'pending', claudeSessionId: null });
318
- expect(taskRepo.update).toHaveBeenCalledWith('task-1', { status: 'pending' });
319
- expect(executionService.spawnTask).toHaveBeenCalledWith(taskWithAgents, '보완 메모', mockRun.id, { testCodeAgentIds: [] });
320
- });
321
-
322
- it('실행 기록이 없으면 버전 1로 시작한다', async () => {
323
- taskRepo.findOne.mockResolvedValue({ ...baseTask, agents: [] });
324
- runRepo.findOne.mockResolvedValue(null);
325
- const mockRun = { id: 1, taskId: 'task-1', version: 1, status: 'running' };
326
- runRepo.save.mockResolvedValue(mockRun);
327
-
328
- await service.rerun('task-1');
329
-
330
- const savedRun = (runRepo.create as jest.Mock).mock.calls[0][0];
331
- expect(savedRun.version).toBe(1);
332
- });
333
-
334
- it('이미 running 상태이면 재실행하지 않는다', async () => {
335
- taskRepo.findOne.mockResolvedValue({ ...baseTask, status: 'running' });
336
-
337
- await service.rerun('task-1');
338
-
339
- expect(executionService.spawnTask).not.toHaveBeenCalled();
340
- });
341
- });
342
-
343
- // ─── stop ─────────────────────────────────────────────────────────────────
344
-
345
- describe('rerunAgent', () => {
346
- it('선택한 에이전트만 다음 버전으로 재실행한다', async () => {
347
- const otherAgent = { ...baseAgent, id: 2, role: 'frontend' as const };
348
- const taskWithAgents = { ...baseTask, agents: [baseAgent, otherAgent] };
349
- taskRepo.findOne.mockResolvedValue(taskWithAgents);
350
- runRepo.findOne.mockResolvedValue({ version: 2 });
351
- const mockRun = { id: 3, taskId: 'task-1', version: 3, status: 'running' };
352
- runRepo.save.mockResolvedValue(mockRun);
353
-
354
- await service.rerunAgent('task-1', 1, 'agent note', true);
355
-
356
- expect(agentRepo.update).toHaveBeenCalledWith(baseAgent.id, { status: 'pending', claudeSessionId: null });
357
- expect(agentRepo.update).not.toHaveBeenCalledWith(otherAgent.id, expect.anything());
358
- expect(taskRepo.update).toHaveBeenCalledWith('task-1', { status: 'pending' });
359
- expect(runRepo.create).toHaveBeenCalledWith({
360
- taskId: 'task-1',
361
- version: 3,
362
- supplementNote: 'agent note',
363
- status: 'running',
364
- });
365
- expect(executionService.spawnTask).toHaveBeenCalledWith(
366
- expect.objectContaining({ agents: [expect.objectContaining({ id: baseAgent.id })] }),
367
- 'agent note',
368
- mockRun.id,
369
- { testCodeAgentIds: [baseAgent.id] },
370
- );
371
- });
372
-
373
- it('대상 에이전트가 없으면 NotFoundException을 던진다', async () => {
374
- taskRepo.findOne.mockResolvedValue({ ...baseTask, agents: [baseAgent] });
375
-
376
- await expect(service.rerunAgent('task-1', 999)).rejects.toThrow(NotFoundException);
377
-
378
- expect(executionService.spawnTask).not.toHaveBeenCalled();
379
- });
380
- });
381
-
382
- describe('stop', () => {
383
- it('실행 중인 task를 중지한다', async () => {
384
- taskRepo.findOne.mockResolvedValue({ ...baseTask, status: 'running' });
385
-
386
- await service.stop('task-1');
387
-
388
- expect(executionService.stopTask).toHaveBeenCalled();
389
- expect(runRepo.update).toHaveBeenCalledWith(
390
- { taskId: 'task-1', status: 'running' },
391
- { status: 'stopped', completedAt: expect.any(Date) },
392
- );
393
- });
394
- });
395
-
396
- // ─── getRuns ─────────────────────────────────────────────────────────────
397
-
398
- describe('getRuns', () => {
399
- it('task의 실행 이력을 버전 내림차순으로 반환한다', async () => {
400
- const runs = [
401
- { id: 2, taskId: 'task-1', version: 2 },
402
- { id: 1, taskId: 'task-1', version: 1 },
403
- ];
404
- runRepo.find.mockResolvedValue(runs);
405
-
406
- const result = await service.getRuns('task-1');
407
-
408
- expect(result).toBe(runs);
409
- expect(runRepo.find).toHaveBeenCalledWith({
410
- where: { taskId: 'task-1' },
411
- relations: ['agentRuns'],
412
- order: { version: 'DESC' },
413
- });
414
- });
415
- });
416
-
417
- // ─── archive ─────────────────────────────────────────────────────────────
418
-
419
- describe('archive', () => {
420
- it('task를 아카이브한다', async () => {
421
- taskRepo.findOne.mockResolvedValue(baseTask);
422
-
423
- await service.archive('task-1');
424
-
425
- expect(taskRepo.update).toHaveBeenCalledWith('task-1', { archived: true });
426
- });
427
-
428
- it('존재하지 않는 task는 NotFoundException을 던진다', async () => {
429
- taskRepo.findOne.mockResolvedValue(null);
430
- await expect(service.archive('not-exist')).rejects.toThrow(NotFoundException);
431
- });
432
- });
433
-
434
- // ─── remove ──────────────────────────────────────────────────────────────
435
-
436
- describe('remove', () => {
437
- it('task를 삭제한다', async () => {
438
- await service.remove('task-1');
439
- expect(taskRepo.delete).toHaveBeenCalledWith('task-1');
440
- });
441
- });
442
-
443
- // ─── mergeAgentAll ───────────────────────────────────────────────────────
444
-
445
- describe('mergeAgentAll', () => {
446
- it('에이전트의 전체 변경사항을 병합한다', async () => {
447
- taskRepo.findOne.mockResolvedValue(baseTask);
448
- agentRepo.findOne.mockResolvedValue(baseAgent);
449
- mockDirectory();
450
-
451
- const result = await service.mergeAgentAll('task-1', 1);
452
-
453
- expect(result).toEqual({ success: true, message: '전체 병합이 완료되었습니다.' });
454
- expect(gitChangelogService.mergeAll).toHaveBeenCalledWith(baseAgent.worktreePath, '/tmp/project');
455
- });
456
-
457
- it('에이전트가 없으면 NotFoundException을 던진다', async () => {
458
- taskRepo.findOne.mockResolvedValue(baseTask);
459
- agentRepo.findOne.mockResolvedValue(null);
460
-
461
- await expect(service.mergeAgentAll('task-1', 999)).rejects.toThrow(NotFoundException);
462
- });
463
-
464
- it('worktreePath가 없으면 실패 메시지를 반환한다', async () => {
465
- taskRepo.findOne.mockResolvedValue(baseTask);
466
- agentRepo.findOne.mockResolvedValue({ ...baseAgent, worktreePath: null });
467
-
468
- const result = await service.mergeAgentAll('task-1', 1);
469
-
470
- expect(result).toEqual({ success: false, message: 'worktree가 존재하지 않습니다.' });
471
- });
472
-
473
- it('workingDir이 없으면 process.cwd()를 사용한다', async () => {
474
- taskRepo.findOne.mockResolvedValue({ ...baseTask, workingDir: null });
475
- agentRepo.findOne.mockResolvedValue(baseAgent);
476
-
477
- const result = await service.mergeAgentAll('task-1', 1);
478
-
479
- expect(result).toEqual({ success: true, message: '전체 병합이 완료되었습니다.' });
480
- expect(fs.existsSync).not.toHaveBeenCalled();
481
- expect(gitChangelogService.mergeAll).toHaveBeenCalledWith(baseAgent.worktreePath, process.cwd());
482
- });
483
-
484
- it('workingDir이 존재하지 않으면 BadRequestException을 던진다', async () => {
485
- taskRepo.findOne.mockResolvedValue(baseTask);
486
- agentRepo.findOne.mockResolvedValue(baseAgent);
487
- (fs.existsSync as jest.Mock).mockReturnValue(false);
488
-
489
- await expect(service.mergeAgentAll('task-1', 1)).rejects.toThrow(BadRequestException);
490
-
491
- expect(gitChangelogService.mergeAll).not.toHaveBeenCalled();
492
- });
493
- });
494
-
495
- // ─── mergeAgentFile ──────────────────────────────────────────────────────
496
-
497
- describe('mergeAgentFile', () => {
498
- it('에이전트의 단일 파일을 병합한다', async () => {
499
- taskRepo.findOne.mockResolvedValue(baseTask);
500
- agentRepo.findOne.mockResolvedValue(baseAgent);
501
- mockDirectory();
502
-
503
- const result = await service.mergeAgentFile('task-1', 1, 'src/app.ts');
504
-
505
- expect(result).toEqual({ success: true, message: 'file.ts 병합이 완료되었습니다.' });
506
- expect(gitChangelogService.getByTask).toHaveBeenCalledWith('task-1');
507
- expect(gitChangelogService.mergeFile).toHaveBeenCalledWith(baseAgent.worktreePath, '/tmp/project', 'src/app.ts');
508
- });
509
-
510
- it('에이전트가 없으면 NotFoundException을 던진다', async () => {
511
- taskRepo.findOne.mockResolvedValue(baseTask);
512
- agentRepo.findOne.mockResolvedValue(null);
513
-
514
- await expect(service.mergeAgentFile('task-1', 999, 'file.ts')).rejects.toThrow(NotFoundException);
515
- });
516
-
517
- it('worktreePath가 없으면 실패 메시지를 반환한다', async () => {
518
- taskRepo.findOne.mockResolvedValue(baseTask);
519
- agentRepo.findOne.mockResolvedValue({ ...baseAgent, worktreePath: null });
520
-
521
- const result = await service.mergeAgentFile('task-1', 1, 'file.ts');
522
-
523
- expect(result).toEqual({ success: false, message: 'worktree가 존재하지 않습니다.' });
524
- });
525
-
526
- it('changelog에 없는 파일이면 BadRequestException을 던지고 병합하지 않는다', async () => {
527
- taskRepo.findOne.mockResolvedValue(baseTask);
528
- agentRepo.findOne.mockResolvedValue(baseAgent);
529
- gitChangelogService.getByTask.mockResolvedValueOnce([
530
- { agentId: 1, files: [{ id: 1, filePath: 'src/allowed.ts', changeType: 'modified', additions: 1, deletions: 0, patch: null }] },
531
- ]);
532
- mockDirectory();
533
-
534
- await expect(service.mergeAgentFile('task-1', 1, 'src/app.ts')).rejects.toThrow(BadRequestException);
535
-
536
- expect(gitChangelogService.mergeFile).not.toHaveBeenCalled();
537
- });
538
-
539
- it('다른 agent의 changelog 파일이면 병합하지 않는다', async () => {
540
- taskRepo.findOne.mockResolvedValue(baseTask);
541
- agentRepo.findOne.mockResolvedValue(baseAgent);
542
- gitChangelogService.getByTask.mockResolvedValueOnce([
543
- { agentId: 2, files: [{ id: 1, filePath: 'src/app.ts', changeType: 'modified', additions: 1, deletions: 0, patch: null }] },
544
- ]);
545
- mockDirectory();
546
-
547
- await expect(service.mergeAgentFile('task-1', 1, 'src/app.ts')).rejects.toThrow(BadRequestException);
548
-
549
- expect(gitChangelogService.mergeFile).not.toHaveBeenCalled();
550
- });
551
- });
552
- });