@evolith/smart-cli 1.1.0 → 1.1.2

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 (481) hide show
  1. package/ARCHITECTURE.md +1 -1
  2. package/LICENSE +21 -0
  3. package/README.es.md +31 -3
  4. package/README.md +915 -170
  5. package/package.json +50 -41
  6. package/shell/hooks.bash +68 -0
  7. package/shell/hooks.fish +57 -0
  8. package/shell/hooks.zsh +68 -0
  9. package/dist/app.module.d.ts +0 -2
  10. package/dist/app.module.js +0 -61
  11. package/dist/app.module.js.map +0 -1
  12. package/dist/app.module.spec.d.ts +0 -1
  13. package/dist/app.module.spec.js +0 -305
  14. package/dist/app.module.spec.js.map +0 -1
  15. package/dist/application/ports/webhook-notifier.port.d.ts +0 -4
  16. package/dist/application/ports/webhook-notifier.port.js +0 -3
  17. package/dist/application/ports/webhook-notifier.port.js.map +0 -1
  18. package/dist/application/services/index.d.ts +0 -64
  19. package/dist/application/services/index.js +0 -371
  20. package/dist/application/services/index.js.map +0 -1
  21. package/dist/application/services/initialize-project.spec.d.ts +0 -1
  22. package/dist/application/services/initialize-project.spec.js +0 -211
  23. package/dist/application/services/initialize-project.spec.js.map +0 -1
  24. package/dist/application/services/phase-transition.use-case.spec.d.ts +0 -1
  25. package/dist/application/services/phase-transition.use-case.spec.js +0 -297
  26. package/dist/application/services/phase-transition.use-case.spec.js.map +0 -1
  27. package/dist/application/services/services.test.d.ts +0 -1
  28. package/dist/application/services/services.test.js +0 -176
  29. package/dist/application/services/services.test.js.map +0 -1
  30. package/dist/application/use-cases/evaluate-gate.use-case.d.ts +0 -20
  31. package/dist/application/use-cases/evaluate-gate.use-case.js +0 -72
  32. package/dist/application/use-cases/evaluate-gate.use-case.js.map +0 -1
  33. package/dist/application/use-cases/validate-satellite.use-case.d.ts +0 -19
  34. package/dist/application/use-cases/validate-satellite.use-case.js +0 -96
  35. package/dist/application/use-cases/validate-satellite.use-case.js.map +0 -1
  36. package/dist/application/use-cases/validate-satellite.use-case.spec.d.ts +0 -1
  37. package/dist/application/use-cases/validate-satellite.use-case.spec.js +0 -102
  38. package/dist/application/use-cases/validate-satellite.use-case.spec.js.map +0 -1
  39. package/dist/commands/adr/adr.command.d.ts +0 -30
  40. package/dist/commands/adr/adr.command.js +0 -379
  41. package/dist/commands/adr/adr.command.js.map +0 -1
  42. package/dist/commands/adr/adr.command.spec.d.ts +0 -1
  43. package/dist/commands/adr/adr.command.spec.js +0 -409
  44. package/dist/commands/adr/adr.command.spec.js.map +0 -1
  45. package/dist/commands/architecture/scaffold.command.d.ts +0 -8
  46. package/dist/commands/architecture/scaffold.command.js +0 -184
  47. package/dist/commands/architecture/scaffold.command.js.map +0 -1
  48. package/dist/commands/architecture/scaffold.command.spec.d.ts +0 -1
  49. package/dist/commands/architecture/scaffold.command.spec.js +0 -207
  50. package/dist/commands/architecture/scaffold.command.spec.js.map +0 -1
  51. package/dist/commands/commands.test.d.ts +0 -1
  52. package/dist/commands/commands.test.js +0 -131
  53. package/dist/commands/commands.test.js.map +0 -1
  54. package/dist/commands/completion/completion.command.d.ts +0 -20
  55. package/dist/commands/completion/completion.command.js +0 -215
  56. package/dist/commands/completion/completion.command.js.map +0 -1
  57. package/dist/commands/completion/completion.command.spec.d.ts +0 -1
  58. package/dist/commands/completion/completion.command.spec.js +0 -240
  59. package/dist/commands/completion/completion.command.spec.js.map +0 -1
  60. package/dist/commands/docs/docs.command.d.ts +0 -14
  61. package/dist/commands/docs/docs.command.js +0 -233
  62. package/dist/commands/docs/docs.command.js.map +0 -1
  63. package/dist/commands/docs/docs.command.spec.d.ts +0 -1
  64. package/dist/commands/docs/docs.command.spec.js +0 -87
  65. package/dist/commands/docs/docs.command.spec.js.map +0 -1
  66. package/dist/commands/drift/drift.command.d.ts +0 -24
  67. package/dist/commands/drift/drift.command.js +0 -250
  68. package/dist/commands/drift/drift.command.js.map +0 -1
  69. package/dist/commands/drift/drift.command.spec.d.ts +0 -1
  70. package/dist/commands/drift/drift.command.spec.js +0 -327
  71. package/dist/commands/drift/drift.command.spec.js.map +0 -1
  72. package/dist/commands/gate/gate.command.d.ts +0 -23
  73. package/dist/commands/gate/gate.command.js +0 -210
  74. package/dist/commands/gate/gate.command.js.map +0 -1
  75. package/dist/commands/history/history.command.d.ts +0 -29
  76. package/dist/commands/history/history.command.js +0 -268
  77. package/dist/commands/history/history.command.js.map +0 -1
  78. package/dist/commands/history/history.command.spec.d.ts +0 -1
  79. package/dist/commands/history/history.command.spec.js +0 -392
  80. package/dist/commands/history/history.command.spec.js.map +0 -1
  81. package/dist/commands/init/agents.command.d.ts +0 -22
  82. package/dist/commands/init/agents.command.js +0 -502
  83. package/dist/commands/init/agents.command.js.map +0 -1
  84. package/dist/commands/init/agents.command.spec.d.ts +0 -1
  85. package/dist/commands/init/agents.command.spec.js +0 -550
  86. package/dist/commands/init/agents.command.spec.js.map +0 -1
  87. package/dist/commands/init/init.command.d.ts +0 -20
  88. package/dist/commands/init/init.command.js +0 -329
  89. package/dist/commands/init/init.command.js.map +0 -1
  90. package/dist/commands/init/init.command.spec.d.ts +0 -1
  91. package/dist/commands/init/init.command.spec.js +0 -272
  92. package/dist/commands/init/init.command.spec.js.map +0 -1
  93. package/dist/commands/init/upgrade.command.d.ts +0 -19
  94. package/dist/commands/init/upgrade.command.js +0 -210
  95. package/dist/commands/init/upgrade.command.js.map +0 -1
  96. package/dist/commands/init/upgrade.command.spec.d.ts +0 -1
  97. package/dist/commands/init/upgrade.command.spec.js +0 -378
  98. package/dist/commands/init/upgrade.command.spec.js.map +0 -1
  99. package/dist/commands/mcp/mcp-serve.command.d.ts +0 -15
  100. package/dist/commands/mcp/mcp-serve.command.js +0 -106
  101. package/dist/commands/mcp/mcp-serve.command.js.map +0 -1
  102. package/dist/commands/mcp/mcp-serve.command.spec.d.ts +0 -1
  103. package/dist/commands/mcp/mcp-serve.command.spec.js +0 -58
  104. package/dist/commands/mcp/mcp-serve.command.spec.js.map +0 -1
  105. package/dist/commands/sdlc/gate-status.command.d.ts +0 -7
  106. package/dist/commands/sdlc/gate-status.command.js +0 -189
  107. package/dist/commands/sdlc/gate-status.command.js.map +0 -1
  108. package/dist/commands/sdlc/gate-status.command.spec.d.ts +0 -1
  109. package/dist/commands/sdlc/gate-status.command.spec.js +0 -302
  110. package/dist/commands/sdlc/gate-status.command.spec.js.map +0 -1
  111. package/dist/commands/sdlc/generate-domain.command.d.ts +0 -7
  112. package/dist/commands/sdlc/generate-domain.command.js +0 -166
  113. package/dist/commands/sdlc/generate-domain.command.js.map +0 -1
  114. package/dist/commands/sdlc/generate-domain.command.spec.d.ts +0 -1
  115. package/dist/commands/sdlc/generate-domain.command.spec.js +0 -121
  116. package/dist/commands/sdlc/generate-domain.command.spec.js.map +0 -1
  117. package/dist/commands/sdlc/handoff.command.d.ts +0 -22
  118. package/dist/commands/sdlc/handoff.command.js +0 -273
  119. package/dist/commands/sdlc/handoff.command.js.map +0 -1
  120. package/dist/commands/sdlc/handoff.command.spec.d.ts +0 -1
  121. package/dist/commands/sdlc/handoff.command.spec.js +0 -395
  122. package/dist/commands/sdlc/handoff.command.spec.js.map +0 -1
  123. package/dist/commands/sdlc/sdlc.command.d.ts +0 -4
  124. package/dist/commands/sdlc/sdlc.command.js +0 -70
  125. package/dist/commands/sdlc/sdlc.command.js.map +0 -1
  126. package/dist/commands/sdlc/sdlc.command.spec.d.ts +0 -1
  127. package/dist/commands/sdlc/sdlc.command.spec.js +0 -79
  128. package/dist/commands/sdlc/sdlc.command.spec.js.map +0 -1
  129. package/dist/commands/standards/standards.command.d.ts +0 -27
  130. package/dist/commands/standards/standards.command.js +0 -308
  131. package/dist/commands/standards/standards.command.js.map +0 -1
  132. package/dist/commands/standards/standards.command.spec.d.ts +0 -1
  133. package/dist/commands/standards/standards.command.spec.js +0 -311
  134. package/dist/commands/standards/standards.command.spec.js.map +0 -1
  135. package/dist/commands/validate/validate.command.d.ts +0 -25
  136. package/dist/commands/validate/validate.command.js +0 -284
  137. package/dist/commands/validate/validate.command.js.map +0 -1
  138. package/dist/commands/validate/validate.command.spec.d.ts +0 -1
  139. package/dist/commands/validate/validate.command.spec.js +0 -368
  140. package/dist/commands/validate/validate.command.spec.js.map +0 -1
  141. package/dist/config/runtimes.json +0 -196
  142. package/dist/config/tool-catalog.json +0 -343
  143. package/dist/core/abstractions/index.d.ts +0 -6
  144. package/dist/core/abstractions/index.js +0 -23
  145. package/dist/core/abstractions/index.js.map +0 -1
  146. package/dist/core/abstractions/interfaces.d.ts +0 -61
  147. package/dist/core/abstractions/interfaces.js +0 -5
  148. package/dist/core/abstractions/interfaces.js.map +0 -1
  149. package/dist/core/abstractions/providers/config-parser.provider.d.ts +0 -15
  150. package/dist/core/abstractions/providers/config-parser.provider.js +0 -68
  151. package/dist/core/abstractions/providers/config-parser.provider.js.map +0 -1
  152. package/dist/core/abstractions/providers/config-parser.provider.spec.d.ts +0 -1
  153. package/dist/core/abstractions/providers/config-parser.provider.spec.js +0 -18
  154. package/dist/core/abstractions/providers/config-parser.provider.spec.js.map +0 -1
  155. package/dist/core/abstractions/providers/logger.provider.d.ts +0 -10
  156. package/dist/core/abstractions/providers/logger.provider.js +0 -84
  157. package/dist/core/abstractions/providers/logger.provider.js.map +0 -1
  158. package/dist/core/abstractions/providers/logger.provider.spec.d.ts +0 -1
  159. package/dist/core/abstractions/providers/logger.provider.spec.js +0 -212
  160. package/dist/core/abstractions/providers/logger.provider.spec.js.map +0 -1
  161. package/dist/core/abstractions/providers/mock-filesystem.provider.d.ts +0 -31
  162. package/dist/core/abstractions/providers/mock-filesystem.provider.js +0 -126
  163. package/dist/core/abstractions/providers/mock-filesystem.provider.js.map +0 -1
  164. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.d.ts +0 -1
  165. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js +0 -56
  166. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js.map +0 -1
  167. package/dist/core/abstractions/providers/node-filesystem.provider.d.ts +0 -20
  168. package/dist/core/abstractions/providers/node-filesystem.provider.js +0 -108
  169. package/dist/core/abstractions/providers/node-filesystem.provider.js.map +0 -1
  170. package/dist/core/agents/agent-ruleset-builder.d.ts +0 -30
  171. package/dist/core/agents/agent-ruleset-builder.js +0 -75
  172. package/dist/core/agents/agent-ruleset-builder.js.map +0 -1
  173. package/dist/core/agents/agent-ruleset-builder.spec.d.ts +0 -1
  174. package/dist/core/agents/agent-ruleset-builder.spec.js +0 -135
  175. package/dist/core/agents/agent-ruleset-builder.spec.js.map +0 -1
  176. package/dist/core/architecture/nx-workspace.strategy.d.ts +0 -14
  177. package/dist/core/architecture/nx-workspace.strategy.js +0 -136
  178. package/dist/core/architecture/nx-workspace.strategy.js.map +0 -1
  179. package/dist/core/architecture/nx-workspace.strategy.spec.d.ts +0 -1
  180. package/dist/core/architecture/nx-workspace.strategy.spec.js +0 -187
  181. package/dist/core/architecture/nx-workspace.strategy.spec.js.map +0 -1
  182. package/dist/core/architecture/workspace-manager.strategy.d.ts +0 -8
  183. package/dist/core/architecture/workspace-manager.strategy.js +0 -3
  184. package/dist/core/architecture/workspace-manager.strategy.js.map +0 -1
  185. package/dist/core/config/config.service.d.ts +0 -15
  186. package/dist/core/config/config.service.js +0 -55
  187. package/dist/core/config/config.service.js.map +0 -1
  188. package/dist/core/config/config.service.spec.d.ts +0 -1
  189. package/dist/core/config/config.service.spec.js +0 -43
  190. package/dist/core/config/config.service.spec.js.map +0 -1
  191. package/dist/core/di/container.d.ts +0 -25
  192. package/dist/core/di/container.js +0 -87
  193. package/dist/core/di/container.js.map +0 -1
  194. package/dist/core/di/container.spec.d.ts +0 -1
  195. package/dist/core/di/container.spec.js +0 -301
  196. package/dist/core/di/container.spec.js.map +0 -1
  197. package/dist/core/errors/index.d.ts +0 -26
  198. package/dist/core/errors/index.js +0 -67
  199. package/dist/core/errors/index.js.map +0 -1
  200. package/dist/core/filesystem/file-manager.service.d.ts +0 -4
  201. package/dist/core/filesystem/file-manager.service.js +0 -96
  202. package/dist/core/filesystem/file-manager.service.js.map +0 -1
  203. package/dist/core/filesystem/file-manager.service.spec.d.ts +0 -1
  204. package/dist/core/filesystem/file-manager.service.spec.js +0 -103
  205. package/dist/core/filesystem/file-manager.service.spec.js.map +0 -1
  206. package/dist/core/generators/hexagonal-scaffolder.d.ts +0 -6
  207. package/dist/core/generators/hexagonal-scaffolder.js +0 -260
  208. package/dist/core/generators/hexagonal-scaffolder.js.map +0 -1
  209. package/dist/core/generators/hexagonal-scaffolder.spec.d.ts +0 -1
  210. package/dist/core/generators/hexagonal-scaffolder.spec.js +0 -164
  211. package/dist/core/generators/hexagonal-scaffolder.spec.js.map +0 -1
  212. package/dist/core/generators/mermaid-class-parser.d.ts +0 -38
  213. package/dist/core/generators/mermaid-class-parser.js +0 -183
  214. package/dist/core/generators/mermaid-class-parser.js.map +0 -1
  215. package/dist/core/generators/mermaid-class-parser.spec.d.ts +0 -1
  216. package/dist/core/generators/mermaid-class-parser.spec.js +0 -148
  217. package/dist/core/generators/mermaid-class-parser.spec.js.map +0 -1
  218. package/dist/core/mcp/mcp-server.service.d.ts +0 -7
  219. package/dist/core/mcp/mcp-server.service.js +0 -31
  220. package/dist/core/mcp/mcp-server.service.js.map +0 -1
  221. package/dist/core/mcp/metrics.service.d.ts +0 -37
  222. package/dist/core/mcp/metrics.service.js +0 -72
  223. package/dist/core/mcp/metrics.service.js.map +0 -1
  224. package/dist/core/mcp/metrics.service.spec.d.ts +0 -1
  225. package/dist/core/mcp/metrics.service.spec.js +0 -159
  226. package/dist/core/mcp/metrics.service.spec.js.map +0 -1
  227. package/dist/core/mcp/prompts/index.d.ts +0 -22
  228. package/dist/core/mcp/prompts/index.js +0 -211
  229. package/dist/core/mcp/prompts/index.js.map +0 -1
  230. package/dist/core/mcp/prompts/index.spec.d.ts +0 -1
  231. package/dist/core/mcp/prompts/index.spec.js +0 -150
  232. package/dist/core/mcp/prompts/index.spec.js.map +0 -1
  233. package/dist/core/mcp/resources/index.d.ts +0 -11
  234. package/dist/core/mcp/resources/index.js +0 -209
  235. package/dist/core/mcp/resources/index.js.map +0 -1
  236. package/dist/core/mcp/resources/index.spec.d.ts +0 -1
  237. package/dist/core/mcp/resources/index.spec.js +0 -212
  238. package/dist/core/mcp/resources/index.spec.js.map +0 -1
  239. package/dist/core/mcp/server.d.ts +0 -33
  240. package/dist/core/mcp/server.js +0 -693
  241. package/dist/core/mcp/server.js.map +0 -1
  242. package/dist/core/mcp/server.spec.d.ts +0 -1
  243. package/dist/core/mcp/server.spec.js +0 -579
  244. package/dist/core/mcp/server.spec.js.map +0 -1
  245. package/dist/core/mcp/tools/agent.d.ts +0 -41
  246. package/dist/core/mcp/tools/agent.js +0 -195
  247. package/dist/core/mcp/tools/agent.js.map +0 -1
  248. package/dist/core/mcp/tools/agent.spec.d.ts +0 -1
  249. package/dist/core/mcp/tools/agent.spec.js +0 -171
  250. package/dist/core/mcp/tools/agent.spec.js.map +0 -1
  251. package/dist/core/mcp/tools/architecture.d.ts +0 -29
  252. package/dist/core/mcp/tools/architecture.js +0 -234
  253. package/dist/core/mcp/tools/architecture.js.map +0 -1
  254. package/dist/core/mcp/tools/architecture.spec.d.ts +0 -1
  255. package/dist/core/mcp/tools/architecture.spec.js +0 -145
  256. package/dist/core/mcp/tools/architecture.spec.js.map +0 -1
  257. package/dist/core/mcp/tools/gate.d.ts +0 -1
  258. package/dist/core/mcp/tools/gate.js +0 -68
  259. package/dist/core/mcp/tools/gate.js.map +0 -1
  260. package/dist/core/mcp/tools/moscow.d.ts +0 -30
  261. package/dist/core/mcp/tools/moscow.js +0 -113
  262. package/dist/core/mcp/tools/moscow.js.map +0 -1
  263. package/dist/core/mcp/tools/moscow.spec.d.ts +0 -1
  264. package/dist/core/mcp/tools/moscow.spec.js +0 -209
  265. package/dist/core/mcp/tools/moscow.spec.js.map +0 -1
  266. package/dist/core/mcp/tools/sdlc.d.ts +0 -32
  267. package/dist/core/mcp/tools/sdlc.js +0 -190
  268. package/dist/core/mcp/tools/sdlc.js.map +0 -1
  269. package/dist/core/mcp/tools/sdlc.spec.d.ts +0 -1
  270. package/dist/core/mcp/tools/sdlc.spec.js +0 -170
  271. package/dist/core/mcp/tools/sdlc.spec.js.map +0 -1
  272. package/dist/core/mcp/tools/tool-utils.d.ts +0 -4
  273. package/dist/core/mcp/tools/tool-utils.js +0 -18
  274. package/dist/core/mcp/tools/tool-utils.js.map +0 -1
  275. package/dist/core/mcp/tools/validate.d.ts +0 -18
  276. package/dist/core/mcp/tools/validate.js +0 -56
  277. package/dist/core/mcp/tools/validate.js.map +0 -1
  278. package/dist/core/mcp/tools/validate.spec.d.ts +0 -1
  279. package/dist/core/mcp/tools/validate.spec.js +0 -130
  280. package/dist/core/mcp/tools/validate.spec.js.map +0 -1
  281. package/dist/core/mcp/watcher.service.d.ts +0 -8
  282. package/dist/core/mcp/watcher.service.js +0 -82
  283. package/dist/core/mcp/watcher.service.js.map +0 -1
  284. package/dist/core/mcp/watcher.service.spec.d.ts +0 -1
  285. package/dist/core/mcp/watcher.service.spec.js +0 -171
  286. package/dist/core/mcp/watcher.service.spec.js.map +0 -1
  287. package/dist/core/metrics/dora-calculator.d.ts +0 -18
  288. package/dist/core/metrics/dora-calculator.js +0 -146
  289. package/dist/core/metrics/dora-calculator.js.map +0 -1
  290. package/dist/core/metrics/dora-calculator.spec.d.ts +0 -1
  291. package/dist/core/metrics/dora-calculator.spec.js +0 -164
  292. package/dist/core/metrics/dora-calculator.spec.js.map +0 -1
  293. package/dist/core/metrics/git-log-reader.d.ts +0 -14
  294. package/dist/core/metrics/git-log-reader.js +0 -39
  295. package/dist/core/metrics/git-log-reader.js.map +0 -1
  296. package/dist/core/metrics/git-log-reader.spec.d.ts +0 -1
  297. package/dist/core/metrics/git-log-reader.spec.js +0 -108
  298. package/dist/core/metrics/git-log-reader.spec.js.map +0 -1
  299. package/dist/core/observability/command-watcher.d.ts +0 -45
  300. package/dist/core/observability/command-watcher.js +0 -168
  301. package/dist/core/observability/command-watcher.js.map +0 -1
  302. package/dist/core/observability/command-watcher.spec.d.ts +0 -1
  303. package/dist/core/observability/command-watcher.spec.js +0 -123
  304. package/dist/core/observability/command-watcher.spec.js.map +0 -1
  305. package/dist/core/observability/error-reporter.d.ts +0 -47
  306. package/dist/core/observability/error-reporter.js +0 -163
  307. package/dist/core/observability/error-reporter.js.map +0 -1
  308. package/dist/core/observability/error-reporter.spec.d.ts +0 -1
  309. package/dist/core/observability/error-reporter.spec.js +0 -291
  310. package/dist/core/observability/error-reporter.spec.js.map +0 -1
  311. package/dist/core/observability/index.d.ts +0 -5
  312. package/dist/core/observability/index.js +0 -26
  313. package/dist/core/observability/index.js.map +0 -1
  314. package/dist/core/observability/observability.test.d.ts +0 -1
  315. package/dist/core/observability/observability.test.js +0 -224
  316. package/dist/core/observability/observability.test.js.map +0 -1
  317. package/dist/core/observability/structured-logger.d.ts +0 -53
  318. package/dist/core/observability/structured-logger.js +0 -123
  319. package/dist/core/observability/structured-logger.js.map +0 -1
  320. package/dist/core/observability/structured-logger.spec.d.ts +0 -1
  321. package/dist/core/observability/structured-logger.spec.js +0 -197
  322. package/dist/core/observability/structured-logger.spec.js.map +0 -1
  323. package/dist/core/observability/timing.d.ts +0 -23
  324. package/dist/core/observability/timing.js +0 -140
  325. package/dist/core/observability/timing.js.map +0 -1
  326. package/dist/core/observability/timing.spec.d.ts +0 -1
  327. package/dist/core/observability/timing.spec.js +0 -216
  328. package/dist/core/observability/timing.spec.js.map +0 -1
  329. package/dist/core/observability/tool-usage-telemetry.service.d.ts +0 -46
  330. package/dist/core/observability/tool-usage-telemetry.service.js +0 -181
  331. package/dist/core/observability/tool-usage-telemetry.service.js.map +0 -1
  332. package/dist/core/services/command-executor.service.d.ts +0 -3
  333. package/dist/core/services/command-executor.service.js +0 -12
  334. package/dist/core/services/command-executor.service.js.map +0 -1
  335. package/dist/core/services/command-history.service.d.ts +0 -39
  336. package/dist/core/services/command-history.service.js +0 -150
  337. package/dist/core/services/command-history.service.js.map +0 -1
  338. package/dist/core/services/command-history.service.spec.d.ts +0 -1
  339. package/dist/core/services/command-history.service.spec.js +0 -257
  340. package/dist/core/services/command-history.service.spec.js.map +0 -1
  341. package/dist/core/services/command-providers.d.ts +0 -1
  342. package/dist/core/services/command-providers.js +0 -17
  343. package/dist/core/services/command-providers.js.map +0 -1
  344. package/dist/core/services/runtime-catalog.service.d.ts +0 -2
  345. package/dist/core/services/runtime-catalog.service.js +0 -7
  346. package/dist/core/services/runtime-catalog.service.js.map +0 -1
  347. package/dist/core/sync/sync.service.d.ts +0 -4
  348. package/dist/core/sync/sync.service.js +0 -81
  349. package/dist/core/sync/sync.service.js.map +0 -1
  350. package/dist/core/sync/sync.service.spec.d.ts +0 -1
  351. package/dist/core/sync/sync.service.spec.js +0 -63
  352. package/dist/core/sync/sync.service.spec.js.map +0 -1
  353. package/dist/core/upgrade/satellite-upgrade.service.d.ts +0 -48
  354. package/dist/core/upgrade/satellite-upgrade.service.js +0 -358
  355. package/dist/core/upgrade/satellite-upgrade.service.js.map +0 -1
  356. package/dist/core/upgrade/satellite-upgrade.service.spec.d.ts +0 -1
  357. package/dist/core/upgrade/satellite-upgrade.service.spec.js +0 -223
  358. package/dist/core/upgrade/satellite-upgrade.service.spec.js.map +0 -1
  359. package/dist/core/validators/architecture-drift.service.d.ts +0 -68
  360. package/dist/core/validators/architecture-drift.service.js +0 -266
  361. package/dist/core/validators/architecture-drift.service.js.map +0 -1
  362. package/dist/core/validators/architecture-drift.service.spec.d.ts +0 -1
  363. package/dist/core/validators/architecture-drift.service.spec.js +0 -315
  364. package/dist/core/validators/architecture-drift.service.spec.js.map +0 -1
  365. package/dist/core/validators/deep-architecture-analyzer.d.ts +0 -58
  366. package/dist/core/validators/deep-architecture-analyzer.js +0 -333
  367. package/dist/core/validators/deep-architecture-analyzer.js.map +0 -1
  368. package/dist/core/validators/deep-architecture-analyzer.spec.d.ts +0 -1
  369. package/dist/core/validators/deep-architecture-analyzer.spec.js +0 -186
  370. package/dist/core/validators/deep-architecture-analyzer.spec.js.map +0 -1
  371. package/dist/core/validators/evaluators/evaluator.interface.d.ts +0 -14
  372. package/dist/core/validators/evaluators/evaluator.interface.js +0 -3
  373. package/dist/core/validators/evaluators/evaluator.interface.js.map +0 -1
  374. package/dist/core/validators/evaluators/native-evaluator.d.ts +0 -31
  375. package/dist/core/validators/evaluators/native-evaluator.js +0 -461
  376. package/dist/core/validators/evaluators/native-evaluator.js.map +0 -1
  377. package/dist/core/validators/evaluators/opa-evaluator.d.ts +0 -20
  378. package/dist/core/validators/evaluators/opa-evaluator.js +0 -249
  379. package/dist/core/validators/evaluators/opa-evaluator.js.map +0 -1
  380. package/dist/core/validators/phase-gate-validator.service.d.ts +0 -75
  381. package/dist/core/validators/phase-gate-validator.service.js +0 -338
  382. package/dist/core/validators/phase-gate-validator.service.js.map +0 -1
  383. package/dist/core/validators/phase-gate-validator.service.spec.d.ts +0 -1
  384. package/dist/core/validators/phase-gate-validator.service.spec.js +0 -326
  385. package/dist/core/validators/phase-gate-validator.service.spec.js.map +0 -1
  386. package/dist/core/validators/rule-evaluation-engine.d.ts +0 -34
  387. package/dist/core/validators/rule-evaluation-engine.js +0 -187
  388. package/dist/core/validators/rule-evaluation-engine.js.map +0 -1
  389. package/dist/core/validators/rule-evaluation-engine.spec.d.ts +0 -1
  390. package/dist/core/validators/rule-evaluation-engine.spec.js +0 -243
  391. package/dist/core/validators/rule-evaluation-engine.spec.js.map +0 -1
  392. package/dist/core/validators/ruleset-validator-architecture.spec.d.ts +0 -1
  393. package/dist/core/validators/ruleset-validator-architecture.spec.js +0 -178
  394. package/dist/core/validators/ruleset-validator-architecture.spec.js.map +0 -1
  395. package/dist/core/validators/ruleset-validator.service.d.ts +0 -82
  396. package/dist/core/validators/ruleset-validator.service.js +0 -682
  397. package/dist/core/validators/ruleset-validator.service.js.map +0 -1
  398. package/dist/core/validators/ruleset-validator.service.spec.d.ts +0 -1
  399. package/dist/core/validators/ruleset-validator.service.spec.js +0 -469
  400. package/dist/core/validators/ruleset-validator.service.spec.js.map +0 -1
  401. package/dist/domain/entities/index.d.ts +0 -72
  402. package/dist/domain/entities/index.js +0 -119
  403. package/dist/domain/entities/index.js.map +0 -1
  404. package/dist/domain/gate-evidence.d.ts +0 -59
  405. package/dist/domain/gate-evidence.js +0 -38
  406. package/dist/domain/gate-evidence.js.map +0 -1
  407. package/dist/domain/interfaces.d.ts +0 -224
  408. package/dist/domain/interfaces.js +0 -3
  409. package/dist/domain/interfaces.js.map +0 -1
  410. package/dist/domain/services/adr.service.d.ts +0 -50
  411. package/dist/domain/services/adr.service.js +0 -129
  412. package/dist/domain/services/adr.service.js.map +0 -1
  413. package/dist/domain/services/adr.service.spec.d.ts +0 -1
  414. package/dist/domain/services/adr.service.spec.js +0 -141
  415. package/dist/domain/services/adr.service.spec.js.map +0 -1
  416. package/dist/domain/services/agent-registry.service.d.ts +0 -26
  417. package/dist/domain/services/agent-registry.service.js +0 -152
  418. package/dist/domain/services/agent-registry.service.js.map +0 -1
  419. package/dist/domain/services/agent-registry.service.spec.d.ts +0 -1
  420. package/dist/domain/services/agent-registry.service.spec.js +0 -162
  421. package/dist/domain/services/agent-registry.service.spec.js.map +0 -1
  422. package/dist/domain/services/index.d.ts +0 -34
  423. package/dist/domain/services/index.js +0 -128
  424. package/dist/domain/services/index.js.map +0 -1
  425. package/dist/domain/services/moscow-prioritization.service.d.ts +0 -44
  426. package/dist/domain/services/moscow-prioritization.service.js +0 -213
  427. package/dist/domain/services/moscow-prioritization.service.js.map +0 -1
  428. package/dist/domain/services/moscow-prioritization.service.spec.d.ts +0 -1
  429. package/dist/domain/services/moscow-prioritization.service.spec.js +0 -285
  430. package/dist/domain/services/moscow-prioritization.service.spec.js.map +0 -1
  431. package/dist/domain/services/services.test.d.ts +0 -1
  432. package/dist/domain/services/services.test.js +0 -236
  433. package/dist/domain/services/services.test.js.map +0 -1
  434. package/dist/domain/services/standards.service.d.ts +0 -47
  435. package/dist/domain/services/standards.service.js +0 -129
  436. package/dist/domain/services/standards.service.js.map +0 -1
  437. package/dist/domain/services/standards.service.spec.d.ts +0 -1
  438. package/dist/domain/services/standards.service.spec.js +0 -600
  439. package/dist/domain/services/standards.service.spec.js.map +0 -1
  440. package/dist/domain/services/tool-usage-telemetry.service.d.ts +0 -46
  441. package/dist/domain/services/tool-usage-telemetry.service.js +0 -181
  442. package/dist/domain/services/tool-usage-telemetry.service.js.map +0 -1
  443. package/dist/domain/services/tool-usage-telemetry.service.spec.d.ts +0 -1
  444. package/dist/domain/services/tool-usage-telemetry.service.spec.js +0 -180
  445. package/dist/domain/services/tool-usage-telemetry.service.spec.js.map +0 -1
  446. package/dist/infrastructure/adapters/webhook.adapter.d.ts +0 -5
  447. package/dist/infrastructure/adapters/webhook.adapter.js +0 -19
  448. package/dist/infrastructure/adapters/webhook.adapter.js.map +0 -1
  449. package/dist/infrastructure/catalog/catalog-loader.d.ts +0 -22
  450. package/dist/infrastructure/catalog/catalog-loader.js +0 -135
  451. package/dist/infrastructure/catalog/catalog-loader.js.map +0 -1
  452. package/dist/infrastructure/catalog/catalog-loader.test.d.ts +0 -1
  453. package/dist/infrastructure/catalog/catalog-loader.test.js +0 -184
  454. package/dist/infrastructure/catalog/catalog-loader.test.js.map +0 -1
  455. package/dist/infrastructure/cli/command-executor.d.ts +0 -20
  456. package/dist/infrastructure/cli/command-executor.js +0 -109
  457. package/dist/infrastructure/cli/command-executor.js.map +0 -1
  458. package/dist/infrastructure/cli/command-executor.spec.d.ts +0 -1
  459. package/dist/infrastructure/cli/command-executor.spec.js +0 -149
  460. package/dist/infrastructure/cli/command-executor.spec.js.map +0 -1
  461. package/dist/infrastructure/cli/command-executor.test.d.ts +0 -1
  462. package/dist/infrastructure/cli/command-executor.test.js +0 -98
  463. package/dist/infrastructure/cli/command-executor.test.js.map +0 -1
  464. package/dist/infrastructure/cli/providers/index.d.ts +0 -52
  465. package/dist/infrastructure/cli/providers/index.js +0 -175
  466. package/dist/infrastructure/cli/providers/index.js.map +0 -1
  467. package/dist/infrastructure/cli/providers/providers.spec.d.ts +0 -1
  468. package/dist/infrastructure/cli/providers/providers.spec.js +0 -251
  469. package/dist/infrastructure/cli/providers/providers.spec.js.map +0 -1
  470. package/dist/infrastructure/formatters/output-formatter.service.d.ts +0 -28
  471. package/dist/infrastructure/formatters/output-formatter.service.js +0 -198
  472. package/dist/infrastructure/formatters/output-formatter.service.js.map +0 -1
  473. package/dist/infrastructure/formatters/output-formatter.service.spec.d.ts +0 -1
  474. package/dist/infrastructure/formatters/output-formatter.service.spec.js +0 -164
  475. package/dist/infrastructure/formatters/output-formatter.service.spec.js.map +0 -1
  476. package/dist/main.d.ts +0 -2
  477. package/dist/main.js +0 -10
  478. package/dist/main.js.map +0 -1
  479. package/dist/test/mocks/index.d.ts +0 -44
  480. package/dist/test/mocks/index.js +0 -135
  481. package/dist/test/mocks/index.js.map +0 -1
@@ -1,297 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const services_1 = require("../../application/services");
4
- const abstractions_1 = require("../../core/abstractions");
5
- const mockRulesetContent = JSON.stringify({
6
- gates: [
7
- {
8
- phase: 1,
9
- name: 'Business Sign-Off',
10
- description: 'Scope frozen; funding authorized.',
11
- mandatoryEvidence: [
12
- { artifact: 'PRD', schemaRef: '../schema/prd.schema.json', validation: 'PRD approved' },
13
- { artifact: 'Discovery Canvas', validation: 'Initiative registered' },
14
- { artifact: 'Business Case ROI', validation: 'Financial viability documented' },
15
- { artifact: 'Ballpark Estimation', validation: 'T-Shirt sizing completed' },
16
- ],
17
- blockingCriteria: [
18
- { criterion: 'Scope is ambiguous', action: 'BLOCK — return to Phase 1' },
19
- { criterion: 'Funding outcome is unclear', action: 'BLOCK — return to Phase 1' },
20
- ],
21
- accountableRole: 'Product Owner',
22
- waiverAuthority: 'Executive Sponsor',
23
- waiverRequiredFields: ['criterion', 'justification', 'risk', 'owner', 'expirationDate', 'mitigationPlan'],
24
- },
25
- {
26
- phase: 2,
27
- name: 'Design Baseline Approved',
28
- description: 'Architecture decisions documented.',
29
- mandatoryEvidence: [
30
- { artifact: 'ADR Registry', validation: 'All architecture decisions have ADR' },
31
- { artifact: 'Functional Stories', validation: 'All stories in Ready state' },
32
- { artifact: 'Bounded Context Map', validation: 'All contexts identified' },
33
- ],
34
- blockingCriteria: [
35
- { criterion: 'Significant architecture decisions are undocumented', action: 'BLOCK — require ADR' },
36
- { criterion: 'Functional stories Lack acceptance criteria', action: 'BLOCK — return to story writing' },
37
- ],
38
- accountableRole: 'Software Architect',
39
- waiverAuthority: 'Architecture Board',
40
- waiverRequiredFields: ['criterion', 'justification', 'risk', 'owner', 'expirationDate', 'mitigationPlan'],
41
- },
42
- ],
43
- });
44
- const createMockFileSystem = (overrides) => {
45
- const mock = {
46
- exists: jest.fn().mockResolvedValue(true),
47
- existsSync: jest.fn().mockReturnValue(true),
48
- readFile: jest.fn().mockImplementation((p) => {
49
- if (p.includes('phase-gates.rules.json'))
50
- return Promise.resolve(mockRulesetContent);
51
- return Promise.resolve('');
52
- }),
53
- readJson: jest.fn().mockResolvedValue({}),
54
- readdirNames: jest.fn().mockResolvedValue([]),
55
- writeFile: jest.fn().mockResolvedValue(undefined),
56
- writeJson: jest.fn().mockResolvedValue(undefined),
57
- ensureDir: jest.fn().mockResolvedValue(undefined),
58
- remove: jest.fn().mockResolvedValue(undefined),
59
- stat: jest.fn().mockResolvedValue({ isDirectory: () => true, isFile: () => false }),
60
- ...overrides,
61
- };
62
- return mock;
63
- };
64
- const mockRuleset = {
65
- gates: [
66
- {
67
- phase: 1,
68
- name: 'Business Sign-Off',
69
- description: 'Scope frozen; funding authorized.',
70
- mandatoryEvidence: [
71
- { artifact: 'PRD', schemaRef: '../schema/prd.schema.json', validation: 'PRD approved' },
72
- { artifact: 'Discovery Canvas', validation: 'Initiative registered' },
73
- { artifact: 'Business Case ROI', validation: 'Financial viability documented' },
74
- { artifact: 'Ballpark Estimation', validation: 'T-Shirt sizing completed' },
75
- ],
76
- blockingCriteria: [
77
- { criterion: 'Scope is ambiguous', action: 'BLOCK — return to Phase 1' },
78
- { criterion: 'Funding outcome is unclear', action: 'BLOCK — return to Phase 1' },
79
- ],
80
- accountableRole: 'Product Owner',
81
- waiverAuthority: 'Executive Sponsor',
82
- waiverRequiredFields: ['criterion', 'justification', 'risk', 'owner', 'expirationDate', 'mitigationPlan'],
83
- },
84
- {
85
- phase: 2,
86
- name: 'Design Baseline Approved',
87
- description: 'Architecture decisions documented.',
88
- mandatoryEvidence: [
89
- { artifact: 'ADR Registry', validation: 'All architecture decisions have ADR' },
90
- { artifact: 'Functional Stories', validation: 'All stories in Ready state' },
91
- { artifact: 'Bounded Context Map', validation: 'All contexts identified' },
92
- ],
93
- blockingCriteria: [
94
- { criterion: 'Significant architecture decisions are undocumented', action: 'BLOCK — require ADR' },
95
- { criterion: 'Functional stories Lack acceptance criteria', action: 'BLOCK — return to story writing' },
96
- ],
97
- accountableRole: 'Software Architect',
98
- waiverAuthority: 'Architecture Board',
99
- waiverRequiredFields: ['criterion', 'justification', 'risk', 'owner', 'expirationDate', 'mitigationPlan'],
100
- },
101
- ],
102
- };
103
- describe('PhaseTransitionUseCase', () => {
104
- let useCase;
105
- let mockFs;
106
- beforeEach(() => {
107
- (0, abstractions_1.resetContainer)();
108
- jest.clearAllMocks();
109
- mockFs = createMockFileSystem();
110
- const mockProvider = {
111
- createFileSystem: () => mockFs,
112
- };
113
- (0, abstractions_1.getContainer)().setFileSystemProvider(mockProvider);
114
- useCase = new services_1.PhaseTransitionUseCase(mockFs, '/core');
115
- });
116
- afterEach(() => {
117
- (0, abstractions_1.resetContainer)();
118
- });
119
- describe('execute', () => {
120
- it('should fail when transitioning between non-consecutive phases', async () => {
121
- const result = await useCase.execute('phase-0', 'phase-2', [], '/project');
122
- expect(result.success).toBe(false);
123
- expect(result.errors).toHaveLength(1);
124
- expect(result.errors[0]).toContain('Invalid phase transition');
125
- });
126
- it('should fail for invalid phase values', async () => {
127
- const result = await useCase.execute('invalid', 'phase-1', [], '/project');
128
- expect(result.success).toBe(false);
129
- expect(result.errors[0]).toContain('Invalid phase transition');
130
- });
131
- it('should track executed tools', async () => {
132
- const tools = ['package-json', 'typescript', 'eslint'];
133
- const result = await useCase.execute('phase-0', 'phase-1', tools, '/project');
134
- expect(result.executedTools).toEqual(tools);
135
- });
136
- it('should succeed with empty tools array', async () => {
137
- const result = await useCase.execute('phase-0', 'phase-1', [], '/project');
138
- expect(result.executedTools).toEqual([]);
139
- });
140
- it('should transition from phase-1 to phase-2', async () => {
141
- const result = await useCase.execute('phase-1', 'phase-2', [], '/project');
142
- expect(result.from).toBe('phase-1');
143
- expect(result.to).toBe('phase-2');
144
- });
145
- });
146
- describe('getGateStatus', () => {
147
- it('should return gate status summary', async () => {
148
- const status = await useCase.getGateStatus('/project');
149
- expect(status).toHaveProperty('currentPhase');
150
- expect(status).toHaveProperty('gatesPassed');
151
- expect(status).toHaveProperty('gatesFailed');
152
- expect(status).toHaveProperty('gatesPending');
153
- expect(status).toHaveProperty('results');
154
- });
155
- it('should return results array with gate details', async () => {
156
- const status = await useCase.getGateStatus('/project');
157
- expect(Array.isArray(status.results)).toBe(true);
158
- expect(status.results.length).toBeGreaterThan(0);
159
- });
160
- });
161
- describe('validateGatesWithValidator', () => {
162
- it('should return gate results with proper structure', async () => {
163
- const result = await useCase.execute('phase-0', 'phase-1', [], '/project');
164
- result.gateResults.forEach((gate) => {
165
- expect(gate).toHaveProperty('id');
166
- expect(gate).toHaveProperty('passed');
167
- expect(typeof gate.passed).toBe('boolean');
168
- expect(gate).toHaveProperty('description');
169
- expect(gate).toHaveProperty('required');
170
- expect(typeof gate.required).toBe('boolean');
171
- });
172
- });
173
- it('should mark gates as failed when evidence is missing', async () => {
174
- (0, abstractions_1.resetContainer)();
175
- const failingExistsMockFs = createMockFileSystem({
176
- exists: jest.fn().mockImplementation((p) => {
177
- if (p.includes('prd-template.md'))
178
- return Promise.resolve(false);
179
- if (p.includes('discovery-canvas-template.md'))
180
- return Promise.resolve(false);
181
- if (p.includes('phase-gates.rules.json'))
182
- return Promise.resolve(true);
183
- return Promise.resolve(true);
184
- }),
185
- readFile: jest.fn().mockImplementation((p) => {
186
- if (p.includes('phase-gates.rules.json'))
187
- return Promise.resolve(JSON.stringify({
188
- gates: [{
189
- phase: 1,
190
- name: 'Business Sign-Off',
191
- description: 'Scope frozen.',
192
- mandatoryEvidence: [
193
- { artifact: 'PRD', schemaRef: '../schema/prd.schema.json', validation: 'PRD approved' },
194
- { artifact: 'Discovery Canvas', validation: 'Initiative registered' },
195
- { artifact: 'Business Case ROI', validation: 'Financial viability documented' },
196
- { artifact: 'Ballpark Estimation', validation: 'T-Shirt sizing completed' },
197
- ],
198
- blockingCriteria: [],
199
- accountableRole: 'Product Owner',
200
- waiverAuthority: 'Executive Sponsor',
201
- waiverRequiredFields: [],
202
- }],
203
- }));
204
- return Promise.resolve('');
205
- }),
206
- });
207
- const failingExistsProvider = {
208
- createFileSystem: () => failingExistsMockFs,
209
- };
210
- (0, abstractions_1.getContainer)().setFileSystemProvider(failingExistsProvider);
211
- const failingExistsUseCase = new services_1.PhaseTransitionUseCase(failingExistsMockFs, '/core');
212
- const result = await failingExistsUseCase.execute('phase-0', 'phase-1', [], '/project');
213
- const failedGates = result.gateResults.filter((g) => !g.passed);
214
- expect(failedGates.length).toBeGreaterThan(0);
215
- });
216
- });
217
- describe('validateGatesLegacy fallback', () => {
218
- it('should fall back to legacy validation when validator fails', async () => {
219
- (0, abstractions_1.resetContainer)();
220
- const failingMockFs = createMockFileSystem({
221
- readFile: jest.fn().mockImplementation((p) => {
222
- if (p.includes('phase-gates.rules.json'))
223
- return Promise.reject(new Error('Ruleset not found'));
224
- return Promise.resolve('');
225
- }),
226
- });
227
- const failingProvider = {
228
- createFileSystem: () => failingMockFs,
229
- };
230
- (0, abstractions_1.getContainer)().setFileSystemProvider(failingProvider);
231
- const failingUseCase = new services_1.PhaseTransitionUseCase(failingMockFs, '/core');
232
- const result = await failingUseCase.execute('phase-0', 'phase-1', [], '/project');
233
- expect(result).toHaveProperty('gateResults');
234
- expect(Array.isArray(result.gateResults)).toBe(true);
235
- });
236
- it('legacy validation should check evolith.yaml for phase-0', async () => {
237
- (0, abstractions_1.resetContainer)();
238
- const failingMockFs = createMockFileSystem({
239
- readFile: jest.fn().mockImplementation((p) => {
240
- if (p.includes('phase-gates.rules.json'))
241
- return Promise.reject(new Error('Ruleset not found'));
242
- return Promise.resolve('');
243
- }),
244
- exists: jest.fn().mockResolvedValue(true),
245
- readJson: jest.fn().mockResolvedValue({ coreRef: { version: '1.0.0' } }),
246
- });
247
- const failingProvider = {
248
- createFileSystem: () => failingMockFs,
249
- };
250
- (0, abstractions_1.getContainer)().setFileSystemProvider(failingProvider);
251
- const failingUseCase = new services_1.PhaseTransitionUseCase(failingMockFs, '/core');
252
- const result = await failingUseCase.execute('phase-0', 'phase-1', [], '/project');
253
- expect(result.gateResults.length).toBeGreaterThan(0);
254
- expect(result.gateResults[0].id).toMatch(/PG1/);
255
- });
256
- it('legacy validation should check package.json and src for phase-1', async () => {
257
- (0, abstractions_1.resetContainer)();
258
- const failingMockFs = createMockFileSystem({
259
- readFile: jest.fn().mockImplementation((p) => {
260
- if (p.includes('phase-gates.rules.json'))
261
- return Promise.reject(new Error('Ruleset not found'));
262
- return Promise.resolve('');
263
- }),
264
- exists: jest.fn().mockResolvedValue(true),
265
- });
266
- const failingProvider = {
267
- createFileSystem: () => failingMockFs,
268
- };
269
- (0, abstractions_1.getContainer)().setFileSystemProvider(failingProvider);
270
- const failingUseCase = new services_1.PhaseTransitionUseCase(failingMockFs, '/core');
271
- const result = await failingUseCase.execute('phase-1', 'phase-2', [], '/project');
272
- expect(result.gateResults.length).toBeGreaterThan(0);
273
- expect(result.gateResults[0].id).toMatch(/PG2/);
274
- });
275
- });
276
- describe('PhaseTransitionResult', () => {
277
- it('should return complete result structure', async () => {
278
- const result = await useCase.execute('phase-0', 'phase-1', ['tool-1'], '/project');
279
- expect(result).toHaveProperty('success');
280
- expect(result).toHaveProperty('from');
281
- expect(result).toHaveProperty('to');
282
- expect(result).toHaveProperty('gateResults');
283
- expect(result).toHaveProperty('executedTools');
284
- expect(result).toHaveProperty('warnings');
285
- expect(result).toHaveProperty('errors');
286
- });
287
- it('should include warnings array', async () => {
288
- const result = await useCase.execute('phase-0', 'phase-1', [], '/project');
289
- expect(Array.isArray(result.warnings)).toBe(true);
290
- });
291
- it('should include errors array', async () => {
292
- const result = await useCase.execute('phase-0', 'phase-1', [], '/project');
293
- expect(Array.isArray(result.errors)).toBe(true);
294
- });
295
- });
296
- });
297
- //# sourceMappingURL=phase-transition.use-case.spec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"phase-transition.use-case.spec.js","sourceRoot":"","sources":["../../../src/application/services/phase-transition.use-case.spec.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- export {};
@@ -1,176 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const index_1 = require("./index");
4
- const mocks_1 = require("../../../test/mocks");
5
- describe('InitializeProjectUseCase', () => {
6
- let useCase;
7
- let mockFs;
8
- beforeEach(() => {
9
- mockFs = new mocks_1.MockFileSystem();
10
- useCase = new index_1.InitializeProjectUseCase(mockFs);
11
- });
12
- describe('execute', () => {
13
- const validInput = {
14
- name: 'test-project',
15
- runtime: 'nodejs',
16
- monorepo: 'none',
17
- architecture: 'clean',
18
- database: 'postgresql',
19
- apiProtocol: 'rest',
20
- ciCd: 'github',
21
- observability: 'otel',
22
- features: [],
23
- agents: [],
24
- };
25
- it('should return success for valid input', async () => {
26
- const result = await useCase.execute(validInput, '/test/cwd');
27
- expect(result.success).toBe(true);
28
- expect(result.artifacts.length).toBeGreaterThan(0);
29
- expect(result.errors).toHaveLength(0);
30
- });
31
- it('should return error for invalid runtime', async () => {
32
- const invalidInput = { ...validInput, runtime: 'invalid-runtime' };
33
- const result = await useCase.execute(invalidInput, '/test/cwd');
34
- expect(result.success).toBe(false);
35
- expect(result.errors).toContain('Runtime invalid-runtime not found');
36
- });
37
- it('should return error for invalid monorepo', async () => {
38
- const invalidInput = { ...validInput, monorepo: 'invalid-monorepo' };
39
- const result = await useCase.execute(invalidInput, '/test/cwd');
40
- expect(result.success).toBe(false);
41
- expect(result.errors).toContain('Monorepo invalid-monorepo not found');
42
- });
43
- it('should return error for invalid architecture', async () => {
44
- const invalidInput = { ...validInput, architecture: 'invalid-arch' };
45
- const result = await useCase.execute(invalidInput, '/test/cwd');
46
- expect(result.success).toBe(false);
47
- expect(result.errors).toContain('Architecture invalid-arch not found');
48
- });
49
- it('should create evolith.yaml artifact', async () => {
50
- await useCase.execute(validInput, '/test/cwd');
51
- const exists = await mockFs.exists('/test/cwd/test-project/evolith.yaml');
52
- expect(exists).toBe(true);
53
- });
54
- it('should create README files (bilingual)', async () => {
55
- await useCase.execute(validInput, '/test/cwd');
56
- const readmeEn = await mockFs.exists('/test/cwd/test-project/README.md');
57
- const readmeEs = await mockFs.exists('/test/cwd/test-project/README.es.md');
58
- expect(readmeEn).toBe(true);
59
- expect(readmeEs).toBe(true);
60
- });
61
- it('should create package.json for nodejs runtime', async () => {
62
- await useCase.execute(validInput, '/test/cwd');
63
- const pkgJson = await mockFs.exists('/test/cwd/test-project/package.json');
64
- expect(pkgJson).toBe(true);
65
- });
66
- it('should create tsconfig.json for typescript runtime', async () => {
67
- const typescriptInput = { ...validInput, runtime: 'typescript' };
68
- await useCase.execute(typescriptInput, '/test/cwd');
69
- const tsconfig = await mockFs.exists('/test/cwd/test-project/tsconfig.json');
70
- expect(tsconfig).toBe(true);
71
- });
72
- it('should create .csproj for dotnet runtime', async () => {
73
- const dotnetInput = { ...validInput, runtime: 'dotnet' };
74
- await useCase.execute(dotnetInput, '/test/cwd');
75
- const csproj = await mockFs.exists('/test/cwd/test-project/test-project.csproj');
76
- expect(csproj).toBe(true);
77
- });
78
- it('should create requirements.txt for python runtime', async () => {
79
- const pythonInput = { ...validInput, runtime: 'python' };
80
- await useCase.execute(pythonInput, '/test/cwd');
81
- const requirements = await mockFs.exists('/test/cwd/test-project/requirements.txt');
82
- expect(requirements).toBe(true);
83
- });
84
- it('should create ADR directory if adr feature enabled', async () => {
85
- const adrInput = { ...validInput, features: ['adr'] };
86
- await useCase.execute(adrInput, '/test/cwd');
87
- const adrDir = await mockFs.exists('/test/cwd/test-project/reference/architecture/adrs');
88
- expect(adrDir).toBe(true);
89
- });
90
- it('should create hooks directory if hooks feature enabled', async () => {
91
- const hooksInput = { ...validInput, features: ['hooks'] };
92
- await useCase.execute(hooksInput, '/test/cwd');
93
- const hooksDir = await mockFs.exists('/test/cwd/test-project/.husky');
94
- expect(hooksDir).toBe(true);
95
- });
96
- it('should create ACL directory if acl feature enabled', async () => {
97
- const aclInput = { ...validInput, features: ['acl'] };
98
- await useCase.execute(aclInput, '/test/cwd');
99
- const aclDir = await mockFs.exists('/test/cwd/test-project/rulesets/acl');
100
- expect(aclDir).toBe(true);
101
- });
102
- it('should track all created artifacts', async () => {
103
- const result = await useCase.execute(validInput, '/test/cwd');
104
- expect(result.artifacts).toContain('test-project/evolith.yaml');
105
- expect(result.artifacts).toContain('test-project/README.md');
106
- expect(result.artifacts).toContain('test-project/README.es.md');
107
- expect(result.artifacts).toContain('test-project/package.json');
108
- });
109
- it('should warn if runtime platform not detected', async () => {
110
- const result = await useCase.execute(validInput, '/test/cwd');
111
- expect(Array.isArray(result.warnings)).toBe(true);
112
- });
113
- });
114
- });
115
- describe('PhaseTransitionUseCase', () => {
116
- let useCase;
117
- let mockFs;
118
- beforeEach(() => {
119
- mockFs = new mocks_1.MockFileSystem();
120
- mockFs.setJsonFile('/test/cwd/evolith.yaml', {
121
- coreRef: { version: '1.0.0' },
122
- governance: { version: '1.0.0' },
123
- product: { name: 'test', phase: 'phase-0' },
124
- });
125
- useCase = new index_1.PhaseTransitionUseCase(mockFs);
126
- });
127
- describe('execute', () => {
128
- it('should successfully transition from phase-0 to phase-1', async () => {
129
- const result = await useCase.execute('phase-0', 'phase-1', [], '/test/cwd');
130
- expect(result.success).toBe(true);
131
- expect(result.from).toBe('phase-0');
132
- expect(result.to).toBe('phase-1');
133
- });
134
- it('should fail for non-consecutive phases', async () => {
135
- const result = await useCase.execute('phase-0', 'phase-2', [], '/test/cwd');
136
- expect(result.success).toBe(false);
137
- expect(result.errors).toContain('Invalid phase transition: phase-0 → phase-2. Must be consecutive phases.');
138
- });
139
- it('should fail for backwards transition', async () => {
140
- const result = await useCase.execute('phase-2', 'phase-1', [], '/test/cwd');
141
- expect(result.success).toBe(false);
142
- expect(result.errors.some(e => e.includes('Invalid phase transition'))).toBe(true);
143
- });
144
- it('should track executed tools', async () => {
145
- const tools = ['acl', 'adr', 'hooks'];
146
- const result = await useCase.execute('phase-1', 'phase-2', tools, '/test/cwd');
147
- expect(result.executedTools).toEqual(tools);
148
- });
149
- it('should return gate results', async () => {
150
- const result = await useCase.execute('phase-0', 'phase-1', [], '/test/cwd');
151
- expect(Array.isArray(result.gateResults)).toBe(true);
152
- });
153
- it('should validate gates when defined', async () => {
154
- mockFs.setJsonFile('/test/cwd/package.json', { name: 'test', version: '1.0.0' });
155
- mockFs.setDirectory('/test/cwd/src');
156
- const result = await useCase.execute('phase-1', 'phase-2', [], '/test/cwd');
157
- expect(Array.isArray(result.gateResults)).toBe(true);
158
- });
159
- it('should allow transition when all required gates pass', async () => {
160
- mockFs.setJsonFile('/test/cwd/rulesets/acl/anti-corruption-layer.rules.json', { version: '1.0.0' });
161
- mockFs.setDirectory('/test/cwd/rulesets');
162
- mockFs.setDirectory('/test/cwd/.harness');
163
- const result = await useCase.execute('phase-2', 'phase-3', [], '/test/cwd');
164
- expect(result.success).toBe(true);
165
- });
166
- it('should return errors array even on success', async () => {
167
- const result = await useCase.execute('phase-0', 'phase-1', [], '/test/cwd');
168
- expect(Array.isArray(result.errors)).toBe(true);
169
- });
170
- it('should return warnings array even on success', async () => {
171
- const result = await useCase.execute('phase-0', 'phase-1', [], '/test/cwd');
172
- expect(Array.isArray(result.warnings)).toBe(true);
173
- });
174
- });
175
- });
176
- //# sourceMappingURL=services.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"services.test.js","sourceRoot":"","sources":["../../../src/application/services/services.test.ts"],"names":[],"mappings":"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"}
@@ -1,20 +0,0 @@
1
- import { PhaseGateValidatorService } from '../../core/validators/phase-gate-validator.service';
2
- import { EvaluatorKind, GateEvidence, GatePhase } from '../../domain/gate-evidence';
3
- import { WebhookNotifierPort } from '../ports/webhook-notifier.port';
4
- export declare const PHASE_TO_GATE_NUMBER: Record<GatePhase, number>;
5
- export declare const PHASE_GATES_RULESET_REF = "rulesets/sdlc/phase-gates.rules.json";
6
- export interface EvaluateGateInput {
7
- phase: GatePhase;
8
- projectPath: string;
9
- corePath?: string;
10
- evaluatedBy?: EvaluatorKind;
11
- webhookUrl?: string;
12
- }
13
- export declare class EvaluateGateUseCase {
14
- private readonly validatorFactory;
15
- private readonly webhookNotifier?;
16
- constructor(validatorFactory?: (corePath?: string) => PhaseGateValidatorService, webhookNotifier?: WebhookNotifierPort);
17
- execute(input: EvaluateGateInput): Promise<GateEvidence>;
18
- private toViolations;
19
- private slugify;
20
- }
@@ -1,72 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EvaluateGateUseCase = exports.PHASE_GATES_RULESET_REF = exports.PHASE_TO_GATE_NUMBER = void 0;
4
- const phase_gate_validator_service_1 = require("../../core/validators/phase-gate-validator.service");
5
- const gate_evidence_1 = require("../../domain/gate-evidence");
6
- exports.PHASE_TO_GATE_NUMBER = {
7
- discovery: 1,
8
- design: 2,
9
- construction: 3,
10
- qa: 4,
11
- release: 5,
12
- };
13
- exports.PHASE_GATES_RULESET_REF = 'rulesets/sdlc/phase-gates.rules.json';
14
- class EvaluateGateUseCase {
15
- constructor(validatorFactory = corePath => new phase_gate_validator_service_1.PhaseGateValidatorService(corePath), webhookNotifier) {
16
- this.validatorFactory = validatorFactory;
17
- this.webhookNotifier = webhookNotifier;
18
- }
19
- async execute(input) {
20
- const validator = this.validatorFactory(input.corePath);
21
- const gateNumber = exports.PHASE_TO_GATE_NUMBER[input.phase];
22
- const result = await validator.validateGate(gateNumber, input.projectPath);
23
- const rulesetVersion = await validator.getRulesetVersion();
24
- const violations = this.toViolations(result);
25
- const evidence = {
26
- gateId: this.slugify(result.name),
27
- phase: input.phase,
28
- verdict: (0, gate_evidence_1.deriveVerdict)(violations),
29
- rulesetRef: exports.PHASE_GATES_RULESET_REF,
30
- rulesetVersion,
31
- violations,
32
- evaluatedAt: new Date().toISOString(),
33
- evaluatedBy: input.evaluatedBy ?? 'human',
34
- };
35
- if (input.webhookUrl && this.webhookNotifier) {
36
- await this.webhookNotifier.notify(input.webhookUrl, evidence);
37
- }
38
- return evidence;
39
- }
40
- toViolations(result) {
41
- const violations = [];
42
- for (const evidence of result.evidenceResults) {
43
- if (evidence.passed)
44
- continue;
45
- violations.push({
46
- ruleId: `${result.gateId}-EVIDENCE-${this.slugify(evidence.artifact)}`,
47
- severity: evidence.required ? 'error' : 'warning',
48
- location: evidence.artifact,
49
- message: evidence.validationMessage || `Mandatory evidence '${evidence.artifact}' not satisfied`,
50
- });
51
- }
52
- for (const check of result.blockingChecks) {
53
- if (!check.triggered)
54
- continue;
55
- violations.push({
56
- ruleId: `${result.gateId}-BLOCKING-${this.slugify(check.criterion).slice(0, 48)}`,
57
- severity: 'error',
58
- location: result.name,
59
- message: `Blocking criterion triggered: ${check.criterion} — ${check.action}`,
60
- });
61
- }
62
- return violations;
63
- }
64
- slugify(value) {
65
- return value
66
- .toLowerCase()
67
- .replace(/[^a-z0-9]+/g, '-')
68
- .replace(/^-+|-+$/g, '');
69
- }
70
- }
71
- exports.EvaluateGateUseCase = EvaluateGateUseCase;
72
- //# sourceMappingURL=evaluate-gate.use-case.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"evaluate-gate.use-case.js","sourceRoot":"","sources":["../../../src/application/use-cases/evaluate-gate.use-case.ts"],"names":[],"mappings":"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"}
@@ -1,19 +0,0 @@
1
- import { RulesetValidatorService, ValidationResult } from '../../core/validators/ruleset-validator.service';
2
- export interface ValidateSatelliteInput {
3
- satellitePath: string;
4
- corePath?: string;
5
- rulesetId?: string;
6
- engine?: 'native' | 'opa';
7
- }
8
- export interface ValidateSatelliteOutput {
9
- result: ValidationResult;
10
- formattedOutput?: string;
11
- }
12
- export declare class ValidateSatelliteUseCase {
13
- private readonly validator;
14
- constructor(validator?: RulesetValidatorService);
15
- execute(input: ValidateSatelliteInput): Promise<ValidateSatelliteOutput>;
16
- executeWithFormat(input: ValidateSatelliteInput, format: 'json' | 'markdown'): Promise<ValidateSatelliteOutput>;
17
- private formatMarkdown;
18
- private findCoreFromSatellite;
19
- }