@evolith/smart-cli 0.0.2-beta → 1.1.0

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 (271) hide show
  1. package/README.es.md +51 -15
  2. package/README.md +51 -15
  3. package/dist/app.module.js +2 -2
  4. package/dist/app.module.js.map +1 -1
  5. package/dist/app.module.spec.d.ts +1 -0
  6. package/dist/app.module.spec.js +305 -0
  7. package/dist/app.module.spec.js.map +1 -0
  8. package/dist/application/ports/webhook-notifier.port.d.ts +4 -0
  9. package/dist/application/ports/webhook-notifier.port.js +3 -0
  10. package/dist/application/ports/webhook-notifier.port.js.map +1 -0
  11. package/dist/application/services/index.d.ts +1 -0
  12. package/dist/application/services/index.js +28 -2
  13. package/dist/application/services/index.js.map +1 -1
  14. package/dist/application/services/initialize-project.spec.d.ts +1 -0
  15. package/dist/application/services/initialize-project.spec.js +211 -0
  16. package/dist/application/services/initialize-project.spec.js.map +1 -0
  17. package/dist/application/use-cases/evaluate-gate.use-case.d.ts +20 -0
  18. package/dist/application/use-cases/evaluate-gate.use-case.js +72 -0
  19. package/dist/application/use-cases/evaluate-gate.use-case.js.map +1 -0
  20. package/dist/application/use-cases/validate-satellite.use-case.d.ts +1 -0
  21. package/dist/application/use-cases/validate-satellite.use-case.js +7 -3
  22. package/dist/application/use-cases/validate-satellite.use-case.js.map +1 -1
  23. package/dist/commands/adr/adr.command.d.ts +2 -0
  24. package/dist/commands/adr/adr.command.js +36 -14
  25. package/dist/commands/adr/adr.command.js.map +1 -1
  26. package/dist/commands/adr/adr.command.spec.d.ts +1 -0
  27. package/dist/commands/adr/adr.command.spec.js +409 -0
  28. package/dist/commands/adr/adr.command.spec.js.map +1 -0
  29. package/dist/commands/architecture/scaffold.command.d.ts +1 -0
  30. package/dist/commands/architecture/scaffold.command.js +23 -1
  31. package/dist/commands/architecture/scaffold.command.js.map +1 -1
  32. package/dist/commands/architecture/scaffold.command.spec.d.ts +1 -0
  33. package/dist/commands/architecture/scaffold.command.spec.js +207 -0
  34. package/dist/commands/architecture/scaffold.command.spec.js.map +1 -0
  35. package/dist/commands/completion/completion.command.spec.d.ts +1 -0
  36. package/dist/commands/completion/completion.command.spec.js +240 -0
  37. package/dist/commands/completion/completion.command.spec.js.map +1 -0
  38. package/dist/commands/docs/docs.command.spec.d.ts +1 -0
  39. package/dist/commands/docs/docs.command.spec.js +87 -0
  40. package/dist/commands/docs/docs.command.spec.js.map +1 -0
  41. package/dist/commands/drift/drift.command.spec.d.ts +1 -0
  42. package/dist/commands/drift/drift.command.spec.js +327 -0
  43. package/dist/commands/drift/drift.command.spec.js.map +1 -0
  44. package/dist/commands/gate/gate.command.d.ts +23 -0
  45. package/dist/commands/gate/gate.command.js +210 -0
  46. package/dist/commands/gate/gate.command.js.map +1 -0
  47. package/dist/commands/history/history.command.spec.d.ts +1 -0
  48. package/dist/commands/history/history.command.spec.js +392 -0
  49. package/dist/commands/history/history.command.spec.js.map +1 -0
  50. package/dist/commands/init/agents.command.spec.js +398 -0
  51. package/dist/commands/init/agents.command.spec.js.map +1 -1
  52. package/dist/commands/init/init.command.spec.d.ts +1 -0
  53. package/dist/commands/init/init.command.spec.js +272 -0
  54. package/dist/commands/init/init.command.spec.js.map +1 -0
  55. package/dist/commands/init/upgrade.command.spec.d.ts +1 -0
  56. package/dist/commands/init/upgrade.command.spec.js +378 -0
  57. package/dist/commands/init/upgrade.command.spec.js.map +1 -0
  58. package/dist/commands/mcp/mcp-serve.command.spec.d.ts +1 -0
  59. package/dist/commands/mcp/mcp-serve.command.spec.js +58 -0
  60. package/dist/commands/mcp/mcp-serve.command.spec.js.map +1 -0
  61. package/dist/commands/sdlc/gate-status.command.d.ts +3 -1
  62. package/dist/commands/sdlc/gate-status.command.js +78 -3
  63. package/dist/commands/sdlc/gate-status.command.js.map +1 -1
  64. package/dist/commands/sdlc/gate-status.command.spec.d.ts +1 -0
  65. package/dist/commands/sdlc/gate-status.command.spec.js +302 -0
  66. package/dist/commands/sdlc/gate-status.command.spec.js.map +1 -0
  67. package/dist/commands/sdlc/generate-domain.command.d.ts +2 -0
  68. package/dist/commands/sdlc/generate-domain.command.js +123 -12
  69. package/dist/commands/sdlc/generate-domain.command.js.map +1 -1
  70. package/dist/commands/sdlc/generate-domain.command.spec.d.ts +1 -0
  71. package/dist/commands/sdlc/generate-domain.command.spec.js +121 -0
  72. package/dist/commands/sdlc/generate-domain.command.spec.js.map +1 -0
  73. package/dist/commands/sdlc/handoff.command.js +2 -2
  74. package/dist/commands/sdlc/handoff.command.js.map +1 -1
  75. package/dist/commands/sdlc/handoff.command.spec.d.ts +1 -0
  76. package/dist/commands/sdlc/handoff.command.spec.js +395 -0
  77. package/dist/commands/sdlc/handoff.command.spec.js.map +1 -0
  78. package/dist/commands/sdlc/sdlc.command.js +40 -6
  79. package/dist/commands/sdlc/sdlc.command.js.map +1 -1
  80. package/dist/commands/sdlc/sdlc.command.spec.d.ts +1 -0
  81. package/dist/commands/sdlc/sdlc.command.spec.js +79 -0
  82. package/dist/commands/sdlc/sdlc.command.spec.js.map +1 -0
  83. package/dist/commands/standards/standards.command.spec.d.ts +1 -0
  84. package/dist/commands/standards/standards.command.spec.js +311 -0
  85. package/dist/commands/standards/standards.command.spec.js.map +1 -0
  86. package/dist/commands/validate/validate.command.d.ts +2 -0
  87. package/dist/commands/validate/validate.command.js +16 -2
  88. package/dist/commands/validate/validate.command.js.map +1 -1
  89. package/dist/commands/validate/validate.command.spec.d.ts +1 -0
  90. package/dist/commands/validate/validate.command.spec.js +368 -0
  91. package/dist/commands/validate/validate.command.spec.js.map +1 -0
  92. package/dist/core/abstractions/interfaces.d.ts +1 -0
  93. package/dist/core/abstractions/interfaces.js.map +1 -1
  94. package/dist/core/abstractions/providers/config-parser.provider.spec.d.ts +1 -0
  95. package/dist/core/abstractions/providers/config-parser.provider.spec.js +18 -0
  96. package/dist/core/abstractions/providers/config-parser.provider.spec.js.map +1 -0
  97. package/dist/core/abstractions/providers/logger.provider.spec.d.ts +1 -0
  98. package/dist/core/abstractions/providers/logger.provider.spec.js +212 -0
  99. package/dist/core/abstractions/providers/logger.provider.spec.js.map +1 -0
  100. package/dist/core/abstractions/providers/mock-filesystem.provider.d.ts +1 -0
  101. package/dist/core/abstractions/providers/mock-filesystem.provider.js +4 -0
  102. package/dist/core/abstractions/providers/mock-filesystem.provider.js.map +1 -1
  103. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.d.ts +1 -0
  104. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js +56 -0
  105. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js.map +1 -0
  106. package/dist/core/abstractions/providers/node-filesystem.provider.d.ts +1 -0
  107. package/dist/core/abstractions/providers/node-filesystem.provider.js +4 -0
  108. package/dist/core/abstractions/providers/node-filesystem.provider.js.map +1 -1
  109. package/dist/core/architecture/nx-workspace.strategy.d.ts +3 -0
  110. package/dist/core/architecture/nx-workspace.strategy.js +35 -6
  111. package/dist/core/architecture/nx-workspace.strategy.js.map +1 -1
  112. package/dist/core/architecture/nx-workspace.strategy.spec.d.ts +1 -0
  113. package/dist/core/architecture/nx-workspace.strategy.spec.js +187 -0
  114. package/dist/core/architecture/nx-workspace.strategy.spec.js.map +1 -0
  115. package/dist/core/architecture/workspace-manager.strategy.d.ts +1 -0
  116. package/dist/core/di/container.spec.js +164 -0
  117. package/dist/core/di/container.spec.js.map +1 -1
  118. package/dist/core/generators/hexagonal-scaffolder.d.ts +6 -0
  119. package/dist/core/generators/hexagonal-scaffolder.js +260 -0
  120. package/dist/core/generators/hexagonal-scaffolder.js.map +1 -0
  121. package/dist/core/generators/hexagonal-scaffolder.spec.d.ts +1 -0
  122. package/dist/core/generators/hexagonal-scaffolder.spec.js +164 -0
  123. package/dist/core/generators/hexagonal-scaffolder.spec.js.map +1 -0
  124. package/dist/core/generators/mermaid-class-parser.d.ts +38 -0
  125. package/dist/core/generators/mermaid-class-parser.js +183 -0
  126. package/dist/core/generators/mermaid-class-parser.js.map +1 -0
  127. package/dist/core/generators/mermaid-class-parser.spec.d.ts +1 -0
  128. package/dist/core/generators/mermaid-class-parser.spec.js +148 -0
  129. package/dist/core/generators/mermaid-class-parser.spec.js.map +1 -0
  130. package/dist/core/mcp/metrics.service.spec.d.ts +1 -0
  131. package/dist/core/mcp/metrics.service.spec.js +159 -0
  132. package/dist/core/mcp/metrics.service.spec.js.map +1 -0
  133. package/dist/core/mcp/prompts/index.js +36 -0
  134. package/dist/core/mcp/prompts/index.js.map +1 -1
  135. package/dist/core/mcp/prompts/index.spec.d.ts +1 -0
  136. package/dist/core/mcp/prompts/index.spec.js +150 -0
  137. package/dist/core/mcp/prompts/index.spec.js.map +1 -0
  138. package/dist/core/mcp/resources/index.js +16 -0
  139. package/dist/core/mcp/resources/index.js.map +1 -1
  140. package/dist/core/mcp/resources/index.spec.d.ts +1 -0
  141. package/dist/core/mcp/resources/index.spec.js +212 -0
  142. package/dist/core/mcp/resources/index.spec.js.map +1 -0
  143. package/dist/core/mcp/server.d.ts +4 -1
  144. package/dist/core/mcp/server.js +250 -25
  145. package/dist/core/mcp/server.js.map +1 -1
  146. package/dist/core/mcp/server.spec.d.ts +1 -0
  147. package/dist/core/mcp/server.spec.js +579 -0
  148. package/dist/core/mcp/server.spec.js.map +1 -0
  149. package/dist/core/mcp/tools/agent.spec.d.ts +1 -0
  150. package/dist/core/mcp/tools/agent.spec.js +171 -0
  151. package/dist/core/mcp/tools/agent.spec.js.map +1 -0
  152. package/dist/core/mcp/tools/architecture.d.ts +2 -0
  153. package/dist/core/mcp/tools/architecture.js +68 -0
  154. package/dist/core/mcp/tools/architecture.js.map +1 -1
  155. package/dist/core/mcp/tools/architecture.spec.d.ts +1 -0
  156. package/dist/core/mcp/tools/architecture.spec.js +145 -0
  157. package/dist/core/mcp/tools/architecture.spec.js.map +1 -0
  158. package/dist/core/mcp/tools/gate.d.ts +1 -0
  159. package/dist/core/mcp/tools/gate.js +68 -0
  160. package/dist/core/mcp/tools/gate.js.map +1 -0
  161. package/dist/core/mcp/tools/moscow.d.ts +30 -0
  162. package/dist/core/mcp/tools/moscow.js +113 -0
  163. package/dist/core/mcp/tools/moscow.js.map +1 -0
  164. package/dist/core/mcp/tools/moscow.spec.d.ts +1 -0
  165. package/dist/core/mcp/tools/moscow.spec.js +209 -0
  166. package/dist/core/mcp/tools/moscow.spec.js.map +1 -0
  167. package/dist/core/mcp/tools/sdlc.js +2 -1
  168. package/dist/core/mcp/tools/sdlc.js.map +1 -1
  169. package/dist/core/mcp/tools/sdlc.spec.d.ts +1 -0
  170. package/dist/core/mcp/tools/sdlc.spec.js +170 -0
  171. package/dist/core/mcp/tools/sdlc.spec.js.map +1 -0
  172. package/dist/core/mcp/tools/validate.spec.d.ts +1 -0
  173. package/dist/core/mcp/tools/validate.spec.js +130 -0
  174. package/dist/core/mcp/tools/validate.spec.js.map +1 -0
  175. package/dist/core/mcp/watcher.service.spec.js +109 -8
  176. package/dist/core/mcp/watcher.service.spec.js.map +1 -1
  177. package/dist/core/metrics/dora-calculator.d.ts +18 -0
  178. package/dist/core/metrics/dora-calculator.js +146 -0
  179. package/dist/core/metrics/dora-calculator.js.map +1 -0
  180. package/dist/core/metrics/dora-calculator.spec.d.ts +1 -0
  181. package/dist/core/metrics/dora-calculator.spec.js +164 -0
  182. package/dist/core/metrics/dora-calculator.spec.js.map +1 -0
  183. package/dist/core/metrics/git-log-reader.d.ts +14 -0
  184. package/dist/core/metrics/git-log-reader.js +39 -0
  185. package/dist/core/metrics/git-log-reader.js.map +1 -0
  186. package/dist/core/metrics/git-log-reader.spec.d.ts +1 -0
  187. package/dist/core/metrics/git-log-reader.spec.js +108 -0
  188. package/dist/core/metrics/git-log-reader.spec.js.map +1 -0
  189. package/dist/core/observability/command-watcher.spec.d.ts +1 -0
  190. package/dist/core/observability/command-watcher.spec.js +123 -0
  191. package/dist/core/observability/command-watcher.spec.js.map +1 -0
  192. package/dist/core/observability/error-reporter.spec.d.ts +1 -0
  193. package/dist/core/observability/error-reporter.spec.js +291 -0
  194. package/dist/core/observability/error-reporter.spec.js.map +1 -0
  195. package/dist/core/observability/index.d.ts +1 -0
  196. package/dist/core/observability/index.js +3 -1
  197. package/dist/core/observability/index.js.map +1 -1
  198. package/dist/core/observability/structured-logger.spec.d.ts +1 -0
  199. package/dist/core/observability/structured-logger.spec.js +197 -0
  200. package/dist/core/observability/structured-logger.spec.js.map +1 -0
  201. package/dist/core/observability/timing.spec.d.ts +1 -0
  202. package/dist/core/observability/timing.spec.js +216 -0
  203. package/dist/core/observability/timing.spec.js.map +1 -0
  204. package/dist/core/observability/tool-usage-telemetry.service.d.ts +46 -0
  205. package/dist/core/observability/tool-usage-telemetry.service.js +181 -0
  206. package/dist/core/observability/tool-usage-telemetry.service.js.map +1 -0
  207. package/dist/core/services/command-history.service.d.ts +1 -0
  208. package/dist/core/services/command-history.service.js +4 -0
  209. package/dist/core/services/command-history.service.js.map +1 -1
  210. package/dist/core/services/command-history.service.spec.js +217 -126
  211. package/dist/core/services/command-history.service.spec.js.map +1 -1
  212. package/dist/core/upgrade/satellite-upgrade.service.spec.js +212 -132
  213. package/dist/core/upgrade/satellite-upgrade.service.spec.js.map +1 -1
  214. package/dist/core/validators/deep-architecture-analyzer.d.ts +58 -0
  215. package/dist/core/validators/deep-architecture-analyzer.js +333 -0
  216. package/dist/core/validators/deep-architecture-analyzer.js.map +1 -0
  217. package/dist/core/validators/deep-architecture-analyzer.spec.d.ts +1 -0
  218. package/dist/core/validators/deep-architecture-analyzer.spec.js +186 -0
  219. package/dist/core/validators/deep-architecture-analyzer.spec.js.map +1 -0
  220. package/dist/core/validators/evaluators/evaluator.interface.d.ts +14 -0
  221. package/dist/core/validators/evaluators/evaluator.interface.js +3 -0
  222. package/dist/core/validators/evaluators/evaluator.interface.js.map +1 -0
  223. package/dist/core/validators/evaluators/native-evaluator.d.ts +31 -0
  224. package/dist/core/validators/evaluators/native-evaluator.js +461 -0
  225. package/dist/core/validators/evaluators/native-evaluator.js.map +1 -0
  226. package/dist/core/validators/evaluators/opa-evaluator.d.ts +20 -0
  227. package/dist/core/validators/evaluators/opa-evaluator.js +249 -0
  228. package/dist/core/validators/evaluators/opa-evaluator.js.map +1 -0
  229. package/dist/core/validators/phase-gate-validator.service.d.ts +4 -0
  230. package/dist/core/validators/phase-gate-validator.service.js +76 -9
  231. package/dist/core/validators/phase-gate-validator.service.js.map +1 -1
  232. package/dist/core/validators/rule-evaluation-engine.d.ts +34 -0
  233. package/dist/core/validators/rule-evaluation-engine.js +187 -0
  234. package/dist/core/validators/rule-evaluation-engine.js.map +1 -0
  235. package/dist/core/validators/rule-evaluation-engine.spec.d.ts +1 -0
  236. package/dist/core/validators/rule-evaluation-engine.spec.js +243 -0
  237. package/dist/core/validators/rule-evaluation-engine.spec.js.map +1 -0
  238. package/dist/core/validators/ruleset-validator-architecture.spec.js +2 -2
  239. package/dist/core/validators/ruleset-validator-architecture.spec.js.map +1 -1
  240. package/dist/core/validators/ruleset-validator.service.d.ts +2 -0
  241. package/dist/core/validators/ruleset-validator.service.js +36 -11
  242. package/dist/core/validators/ruleset-validator.service.js.map +1 -1
  243. package/dist/core/validators/ruleset-validator.service.spec.js +347 -0
  244. package/dist/core/validators/ruleset-validator.service.spec.js.map +1 -1
  245. package/dist/domain/gate-evidence.d.ts +59 -0
  246. package/dist/domain/gate-evidence.js +38 -0
  247. package/dist/domain/gate-evidence.js.map +1 -0
  248. package/dist/domain/services/adr.service.d.ts +2 -2
  249. package/dist/domain/services/adr.service.js +12 -8
  250. package/dist/domain/services/adr.service.js.map +1 -1
  251. package/dist/domain/services/index.d.ts +1 -0
  252. package/dist/domain/services/index.js +3 -1
  253. package/dist/domain/services/index.js.map +1 -1
  254. package/dist/domain/services/moscow-prioritization.service.d.ts +44 -0
  255. package/dist/domain/services/moscow-prioritization.service.js +213 -0
  256. package/dist/domain/services/moscow-prioritization.service.js.map +1 -0
  257. package/dist/domain/services/moscow-prioritization.service.spec.d.ts +1 -0
  258. package/dist/domain/services/moscow-prioritization.service.spec.js +285 -0
  259. package/dist/domain/services/moscow-prioritization.service.spec.js.map +1 -0
  260. package/dist/domain/services/standards.service.spec.js +461 -1
  261. package/dist/domain/services/standards.service.spec.js.map +1 -1
  262. package/dist/infrastructure/adapters/webhook.adapter.d.ts +5 -0
  263. package/dist/infrastructure/adapters/webhook.adapter.js +19 -0
  264. package/dist/infrastructure/adapters/webhook.adapter.js.map +1 -0
  265. package/dist/infrastructure/cli/command-executor.spec.d.ts +1 -0
  266. package/dist/infrastructure/cli/command-executor.spec.js +149 -0
  267. package/dist/infrastructure/cli/command-executor.spec.js.map +1 -0
  268. package/dist/infrastructure/cli/providers/providers.spec.d.ts +1 -0
  269. package/dist/infrastructure/cli/providers/providers.spec.js +251 -0
  270. package/dist/infrastructure/cli/providers/providers.spec.js.map +1 -0
  271. package/package.json +23 -5
@@ -0,0 +1,272 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ const init_command_1 = require("./init.command");
37
+ jest.mock('@clack/prompts', () => ({
38
+ intro: jest.fn(),
39
+ outro: jest.fn(),
40
+ note: jest.fn(),
41
+ select: jest.fn(),
42
+ text: jest.fn(),
43
+ confirm: jest.fn(),
44
+ multiselect: jest.fn(),
45
+ group: jest.fn(),
46
+ spinner: jest.fn(() => ({ start: jest.fn(), stop: jest.fn() })),
47
+ cancel: jest.fn(),
48
+ log: {
49
+ info: jest.fn(),
50
+ warn: jest.fn(),
51
+ success: jest.fn(),
52
+ error: jest.fn(),
53
+ message: jest.fn(),
54
+ },
55
+ }));
56
+ jest.mock('chalk', () => {
57
+ const chalkFn = (str) => str;
58
+ chalkFn.green = (str) => str;
59
+ chalkFn.red = (str) => str;
60
+ chalkFn.bold = (str) => str;
61
+ chalkFn.yellow = (str) => str;
62
+ chalkFn.blue = (str) => str;
63
+ chalkFn.cyan = (str) => str;
64
+ chalkFn.bgCyan = { white: { bold: (str) => str } };
65
+ return chalkFn;
66
+ });
67
+ jest.mock('../../core/di/container', () => ({
68
+ getContainer: jest.fn(() => ({
69
+ createFileSystem: jest.fn(() => ({
70
+ exists: jest.fn(),
71
+ readFile: jest.fn(),
72
+ writeFile: jest.fn(),
73
+ readJson: jest.fn(),
74
+ writeJson: jest.fn(),
75
+ ensureDir: jest.fn(),
76
+ readdirNames: jest.fn(),
77
+ existsSync: jest.fn(),
78
+ })),
79
+ })),
80
+ }));
81
+ jest.mock('../../infrastructure/catalog/catalog-loader', () => ({
82
+ catalogLoader: {
83
+ loadRuntimeCatalog: jest.fn(() => [
84
+ { id: 'nodejs', name: 'Node.js', defaultVersion: '20.x', language: 'JavaScript', databases: [{ id: 'postgresql', name: 'PostgreSQL', type: 'relational' }] },
85
+ { id: 'dotnet', name: '.NET', defaultVersion: '8.0', language: 'C#', databases: [{ id: 'sqlserver', name: 'SQL Server', type: 'relational' }] },
86
+ ]),
87
+ getMonorepoOptions: jest.fn(() => [
88
+ { id: 'none', name: 'None', description: 'No monorepo' },
89
+ { id: 'nx', name: 'Nx', description: 'Nx monorepo' },
90
+ ]),
91
+ getArchitecturePatterns: jest.fn(() => [
92
+ { id: 'clean', name: 'Clean Architecture', description: 'Clean architecture pattern' },
93
+ { id: 'hexagonal', name: 'Hexagonal', description: 'Hexagonal architecture' },
94
+ ]),
95
+ getDefaultDatabase: jest.fn(() => 'postgresql'),
96
+ getApiProtocols: jest.fn(() => [
97
+ { id: 'rest', name: 'REST', description: 'RESTful API' },
98
+ { id: 'graphql', name: 'GraphQL', description: 'GraphQL API' },
99
+ ]),
100
+ },
101
+ }));
102
+ jest.mock('../../application/services', () => ({
103
+ InitializeProjectUseCase: jest.fn().mockImplementation(() => ({
104
+ execute: jest.fn(),
105
+ })),
106
+ }));
107
+ jest.mock('../../core/observability', () => ({
108
+ logger: {
109
+ info: jest.fn(),
110
+ error: jest.fn(),
111
+ warn: jest.fn(),
112
+ },
113
+ errorReporter: {
114
+ report: jest.fn(),
115
+ printSummary: jest.fn(),
116
+ },
117
+ OperationTimer: jest.fn().mockImplementation(() => ({
118
+ start: jest.fn(),
119
+ end: jest.fn().mockReturnValue(500),
120
+ })),
121
+ commandWatcher: {
122
+ start: jest.fn(),
123
+ end: jest.fn(),
124
+ },
125
+ }));
126
+ const p = __importStar(require("@clack/prompts"));
127
+ const services_1 = require("../../application/services");
128
+ const mockExecute = jest.fn();
129
+ services_1.InitializeProjectUseCase.mockImplementation(() => ({
130
+ execute: mockExecute,
131
+ }));
132
+ describe('InitCommand', () => {
133
+ let command;
134
+ let logSpy;
135
+ let exitSpy;
136
+ const defaultSelection = {
137
+ projectName: 'my-project',
138
+ runtime: 'nodejs',
139
+ monorepo: 'none',
140
+ architecture: 'clean',
141
+ database: 'postgresql',
142
+ apiProtocol: 'rest',
143
+ ciCd: 'github',
144
+ observability: 'otel',
145
+ features: ['adr', 'hooks'],
146
+ agents: ['bmad'],
147
+ confirmInit: true,
148
+ };
149
+ const defaultResult = {
150
+ success: true,
151
+ artifacts: ['my-project/evolith.yaml', 'my-project/README.md'],
152
+ warnings: [],
153
+ errors: [],
154
+ };
155
+ beforeEach(() => {
156
+ command = new init_command_1.InitCommand();
157
+ logSpy = jest.spyOn(console, 'log').mockImplementation(() => { });
158
+ exitSpy = jest.spyOn(process, 'exit').mockImplementation(() => undefined);
159
+ jest.clearAllMocks();
160
+ mockExecute.mockReset();
161
+ mockExecute.mockResolvedValue(defaultResult);
162
+ });
163
+ afterEach(() => {
164
+ logSpy.mockRestore();
165
+ exitSpy.mockRestore();
166
+ });
167
+ describe('run', () => {
168
+ it('should show intro and prompt for project configuration', async () => {
169
+ p.group.mockResolvedValue(defaultSelection);
170
+ await command.run([], {});
171
+ expect(p.intro).toHaveBeenCalled();
172
+ expect(p.group).toHaveBeenCalled();
173
+ });
174
+ it('should call InitializeProjectUseCase with correct input', async () => {
175
+ p.group.mockResolvedValue(defaultSelection);
176
+ await command.run([], {});
177
+ expect(mockExecute).toHaveBeenCalledWith(expect.objectContaining({
178
+ name: 'my-project',
179
+ runtime: 'nodejs',
180
+ monorepo: 'none',
181
+ architecture: 'clean',
182
+ database: 'postgresql',
183
+ apiProtocol: 'rest',
184
+ ciCd: 'github',
185
+ observability: 'otel',
186
+ features: ['adr', 'hooks'],
187
+ agents: ['bmad'],
188
+ }), expect.any(String));
189
+ });
190
+ it('should show success message when initialization succeeds', async () => {
191
+ p.group.mockResolvedValue(defaultSelection);
192
+ await command.run([], {});
193
+ expect(p.log.success).toHaveBeenCalled();
194
+ expect(p.log.info).toHaveBeenCalled();
195
+ });
196
+ it('should show artifacts created in success output', async () => {
197
+ p.group.mockResolvedValue(defaultSelection);
198
+ await command.run([], {});
199
+ expect(p.log.info).toHaveBeenCalledWith(expect.stringContaining('evolith.yaml'));
200
+ });
201
+ it('should show warnings when initialization has warnings', async () => {
202
+ p.group.mockResolvedValue(defaultSelection);
203
+ mockExecute.mockResolvedValue({
204
+ success: true,
205
+ artifacts: ['my-project/evolith.yaml'],
206
+ warnings: ['Platform nodejs not detected'],
207
+ errors: [],
208
+ });
209
+ await command.run([], {});
210
+ expect(p.log.warn).toHaveBeenCalled();
211
+ });
212
+ it('should show error message when initialization fails', async () => {
213
+ p.group.mockResolvedValue(defaultSelection);
214
+ mockExecute.mockResolvedValue({
215
+ success: false,
216
+ artifacts: [],
217
+ warnings: [],
218
+ errors: ['Runtime not found'],
219
+ });
220
+ await command.run([], {});
221
+ expect(p.log.error).toHaveBeenCalled();
222
+ });
223
+ it('should cancel initialization when confirmInit is false', async () => {
224
+ p.group.mockResolvedValue({
225
+ ...defaultSelection,
226
+ confirmInit: false,
227
+ });
228
+ await command.run([], {});
229
+ expect(mockExecute).not.toHaveBeenCalled();
230
+ expect(p.outro).toHaveBeenCalled();
231
+ });
232
+ it('should handle onCancel from p.group', async () => {
233
+ const groupMock = p.group;
234
+ groupMock.mockImplementation(async (_schema, options) => {
235
+ if (options?.onCancel) {
236
+ options.onCancel();
237
+ }
238
+ return {};
239
+ });
240
+ exitSpy.mockImplementation(() => {
241
+ throw new Error('process.exit called');
242
+ });
243
+ await expect(command.run([], {})).rejects.toThrow('process.exit called');
244
+ });
245
+ it('should log operation start', async () => {
246
+ p.group.mockResolvedValue(defaultSelection);
247
+ await command.run([], {});
248
+ expect(p.intro).toHaveBeenCalled();
249
+ });
250
+ });
251
+ describe('option parsers', () => {
252
+ it('should parse dry-run option', () => {
253
+ expect(command.parseDryRun()).toBe(true);
254
+ });
255
+ it('should parse config option', () => {
256
+ expect(command.parseConfig('/path/to/config.json')).toBe('/path/to/config.json');
257
+ });
258
+ it('should parse runtime option', () => {
259
+ expect(command.parseRuntime('nodejs')).toBe('nodejs');
260
+ });
261
+ it('should parse monorepo option', () => {
262
+ expect(command.parseMonorepo('nx')).toBe('nx');
263
+ });
264
+ it('should parse arch option', () => {
265
+ expect(command.parseArch('hexagonal')).toBe('hexagonal');
266
+ });
267
+ it('should parse db option', () => {
268
+ expect(command.parseDb('mongodb')).toBe('mongodb');
269
+ });
270
+ });
271
+ });
272
+ //# sourceMappingURL=init.command.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.command.spec.js","sourceRoot":"","sources":["../../../src/commands/init/init.command.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,378 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ const upgrade_command_1 = require("./upgrade.command");
37
+ jest.mock('@clack/prompts', () => ({
38
+ intro: jest.fn(),
39
+ outro: jest.fn(),
40
+ note: jest.fn(),
41
+ confirm: jest.fn(),
42
+ spinner: jest.fn(() => ({ start: jest.fn(), stop: jest.fn() })),
43
+ log: {
44
+ info: jest.fn(),
45
+ warn: jest.fn(),
46
+ success: jest.fn(),
47
+ error: jest.fn(),
48
+ message: jest.fn(),
49
+ },
50
+ }));
51
+ jest.mock('chalk', () => {
52
+ const chalkFn = (str) => str;
53
+ chalkFn.green = (str) => str;
54
+ chalkFn.red = (str) => str;
55
+ chalkFn.bold = (str) => str;
56
+ chalkFn.yellow = (str) => str;
57
+ chalkFn.blue = (str) => str;
58
+ chalkFn.cyan = (str) => str;
59
+ chalkFn.bgBlueBright = { white: { bold: (str) => str } };
60
+ return chalkFn;
61
+ });
62
+ jest.mock('../../core/upgrade/satellite-upgrade.service', () => ({
63
+ SatelliteUpgradeService: jest.fn().mockImplementation(() => ({
64
+ planUpgrade: jest.fn(),
65
+ executeUpgrade: jest.fn(),
66
+ getUpgradeReport: jest.fn(),
67
+ })),
68
+ }));
69
+ const p = __importStar(require("@clack/prompts"));
70
+ const satellite_upgrade_service_1 = require("../../core/upgrade/satellite-upgrade.service");
71
+ const mockPlanUpgrade = jest.fn();
72
+ const mockExecuteUpgrade = jest.fn();
73
+ const mockGetUpgradeReport = jest.fn();
74
+ satellite_upgrade_service_1.SatelliteUpgradeService.mockImplementation(() => ({
75
+ planUpgrade: mockPlanUpgrade,
76
+ executeUpgrade: mockExecuteUpgrade,
77
+ getUpgradeReport: mockGetUpgradeReport,
78
+ }));
79
+ describe('UpgradeCommand', () => {
80
+ let command;
81
+ let logSpy;
82
+ let exitSpy;
83
+ beforeEach(() => {
84
+ command = new upgrade_command_1.UpgradeCommand();
85
+ logSpy = jest.spyOn(console, 'log').mockImplementation(() => { });
86
+ exitSpy = jest.spyOn(process, 'exit').mockImplementation(() => undefined);
87
+ jest.clearAllMocks();
88
+ mockPlanUpgrade.mockReset();
89
+ mockExecuteUpgrade.mockReset();
90
+ mockGetUpgradeReport.mockReset();
91
+ });
92
+ afterEach(() => {
93
+ logSpy.mockRestore();
94
+ exitSpy.mockRestore();
95
+ });
96
+ describe('run', () => {
97
+ it('should show intro and plan upgrade', async () => {
98
+ mockPlanUpgrade.mockResolvedValue({
99
+ changes: [],
100
+ breakingChanges: [],
101
+ currentVersion: '1.0.0',
102
+ targetVersion: '1.0.0',
103
+ estimatedRisk: 'low',
104
+ });
105
+ await command.run([], {});
106
+ expect(p.intro).toHaveBeenCalled();
107
+ expect(mockPlanUpgrade).toHaveBeenCalled();
108
+ });
109
+ it('should show already up to date when no changes', async () => {
110
+ mockPlanUpgrade.mockResolvedValue({
111
+ changes: [],
112
+ breakingChanges: [],
113
+ currentVersion: '1.0.0',
114
+ targetVersion: '1.0.0',
115
+ estimatedRisk: 'low',
116
+ });
117
+ await command.run([], {});
118
+ expect(p.log.info).toHaveBeenCalledWith(expect.stringContaining('already up to date'));
119
+ expect(p.outro).toHaveBeenCalled();
120
+ });
121
+ it('should run dry run when dryRun option is set', async () => {
122
+ mockPlanUpgrade.mockResolvedValue({
123
+ changes: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'test', breaking: false }],
124
+ breakingChanges: [],
125
+ currentVersion: '1.0.0',
126
+ targetVersion: '1.1.0',
127
+ estimatedRisk: 'low',
128
+ });
129
+ mockExecuteUpgrade.mockResolvedValue({
130
+ success: true,
131
+ changesApplied: 0,
132
+ changesSkipped: 1,
133
+ errors: [],
134
+ warnings: [],
135
+ plan: { changes: [], breakingChanges: [], currentVersion: '1.0.0', targetVersion: '1.1.0', estimatedRisk: 'low', backupRequired: false },
136
+ backupPath: null,
137
+ });
138
+ mockGetUpgradeReport.mockResolvedValue('report');
139
+ await command.run([], { dryRun: true });
140
+ expect(mockExecuteUpgrade).toHaveBeenCalledWith(expect.objectContaining({ dryRun: true }));
141
+ expect(p.log.info).toHaveBeenCalledWith(expect.stringContaining('Dry run complete'));
142
+ });
143
+ it('should cancel upgrade on breaking changes without force', async () => {
144
+ mockPlanUpgrade.mockResolvedValue({
145
+ changes: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
146
+ breakingChanges: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
147
+ currentVersion: '1.0.0',
148
+ targetVersion: '1.1.0',
149
+ estimatedRisk: 'medium',
150
+ });
151
+ await command.run([], {});
152
+ expect(p.log.warn).toHaveBeenCalled();
153
+ expect(p.outro).toHaveBeenCalledWith(expect.stringContaining('Upgrade cancelled'));
154
+ });
155
+ it('should proceed with breaking changes when force is set', async () => {
156
+ mockPlanUpgrade.mockResolvedValue({
157
+ changes: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
158
+ breakingChanges: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
159
+ currentVersion: '1.0.0',
160
+ targetVersion: '1.1.0',
161
+ estimatedRisk: 'medium',
162
+ });
163
+ p.confirm.mockResolvedValue(true);
164
+ mockExecuteUpgrade.mockResolvedValue({
165
+ success: true,
166
+ changesApplied: 1,
167
+ changesSkipped: 0,
168
+ errors: [],
169
+ warnings: [],
170
+ plan: { changes: [], breakingChanges: [], currentVersion: '1.0.0', targetVersion: '1.1.0', estimatedRisk: 'medium', backupRequired: true },
171
+ backupPath: '/backup',
172
+ });
173
+ mockGetUpgradeReport.mockResolvedValue('report');
174
+ await command.run([], { force: true });
175
+ expect(mockExecuteUpgrade).toHaveBeenCalledWith(expect.objectContaining({ force: true }));
176
+ });
177
+ it('should cancel upgrade when user declines confirmation', async () => {
178
+ mockPlanUpgrade.mockResolvedValue({
179
+ changes: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'test', breaking: false }],
180
+ breakingChanges: [],
181
+ currentVersion: '1.0.0',
182
+ targetVersion: '1.1.0',
183
+ estimatedRisk: 'low',
184
+ });
185
+ p.confirm.mockResolvedValue(false);
186
+ await command.run([], {});
187
+ expect(p.outro).toHaveBeenCalledWith(expect.stringContaining('Upgrade cancelled'));
188
+ });
189
+ it('should show success message on successful upgrade', async () => {
190
+ mockPlanUpgrade.mockResolvedValue({
191
+ changes: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'test', breaking: false }],
192
+ breakingChanges: [],
193
+ currentVersion: '1.0.0',
194
+ targetVersion: '1.1.0',
195
+ estimatedRisk: 'low',
196
+ });
197
+ p.confirm.mockResolvedValue(true);
198
+ mockExecuteUpgrade.mockResolvedValue({
199
+ success: true,
200
+ changesApplied: 1,
201
+ changesSkipped: 0,
202
+ errors: [],
203
+ warnings: [],
204
+ plan: { changes: [], breakingChanges: [], currentVersion: '1.0.0', targetVersion: '1.1.0', estimatedRisk: 'low', backupRequired: false },
205
+ backupPath: null,
206
+ });
207
+ mockGetUpgradeReport.mockResolvedValue('report');
208
+ await command.run([], {});
209
+ expect(p.log.success).toHaveBeenCalled();
210
+ expect(p.outro).toHaveBeenCalledWith(expect.stringContaining('Upgrade finished'));
211
+ });
212
+ it('should show error message on failed upgrade', async () => {
213
+ mockPlanUpgrade.mockResolvedValue({
214
+ changes: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'test', breaking: false }],
215
+ breakingChanges: [],
216
+ currentVersion: '1.0.0',
217
+ targetVersion: '1.1.0',
218
+ estimatedRisk: 'low',
219
+ });
220
+ p.confirm.mockResolvedValue(true);
221
+ mockExecuteUpgrade.mockResolvedValue({
222
+ success: false,
223
+ changesApplied: 0,
224
+ changesSkipped: 1,
225
+ errors: ['Some error'],
226
+ warnings: [],
227
+ plan: { changes: [], breakingChanges: [], currentVersion: '1.0.0', targetVersion: '1.1.0', estimatedRisk: 'low', backupRequired: false },
228
+ backupPath: null,
229
+ });
230
+ mockGetUpgradeReport.mockResolvedValue('report');
231
+ await command.run([], {});
232
+ expect(p.log.error).toHaveBeenCalled();
233
+ });
234
+ it('should handle upgrade errors and exit', async () => {
235
+ mockPlanUpgrade.mockRejectedValue(new Error('Upgrade failed'));
236
+ await command.run([], {});
237
+ expect(p.log.error).toHaveBeenCalledWith(expect.stringContaining('Upgrade failed'));
238
+ expect(exitSpy).toHaveBeenCalledWith(1);
239
+ });
240
+ it('should handle non-Error exceptions', async () => {
241
+ mockPlanUpgrade.mockRejectedValue('string error');
242
+ await command.run([], {});
243
+ expect(p.log.error).toHaveBeenCalledWith(expect.stringContaining('Upgrade failed'));
244
+ expect(exitSpy).toHaveBeenCalledWith(1);
245
+ });
246
+ it('should use custom core path when provided', async () => {
247
+ mockPlanUpgrade.mockResolvedValue({
248
+ changes: [],
249
+ breakingChanges: [],
250
+ currentVersion: '1.0.0',
251
+ targetVersion: '1.0.0',
252
+ estimatedRisk: 'low',
253
+ });
254
+ await command.run([], { core: '/custom/core' });
255
+ expect(mockPlanUpgrade).toHaveBeenCalledWith(expect.objectContaining({ corePath: '/custom/core' }));
256
+ });
257
+ });
258
+ describe('printUpgradePlan', () => {
259
+ it('should print upgrade plan with changes', () => {
260
+ const plan = {
261
+ currentVersion: '1.0.0',
262
+ targetVersion: '1.1.0',
263
+ estimatedRisk: 'low',
264
+ changes: [
265
+ { type: 'add', sourcePath: '/s', targetPath: '/t', description: 'Add feature', breaking: false },
266
+ { type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'Modify feature', breaking: false },
267
+ ],
268
+ breakingChanges: [],
269
+ };
270
+ command.printUpgradePlan(plan);
271
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Upgrade Plan'));
272
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Current Version:'));
273
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Target Version:'));
274
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Risk Level:'));
275
+ });
276
+ it('should print high risk level', () => {
277
+ const plan = {
278
+ currentVersion: '1.0.0',
279
+ targetVersion: '2.0.0',
280
+ estimatedRisk: 'high',
281
+ changes: [],
282
+ breakingChanges: [],
283
+ };
284
+ command.printUpgradePlan(plan);
285
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('HIGH'));
286
+ });
287
+ it('should print medium risk level', () => {
288
+ const plan = {
289
+ currentVersion: '1.0.0',
290
+ targetVersion: '1.5.0',
291
+ estimatedRisk: 'medium',
292
+ changes: [],
293
+ breakingChanges: [],
294
+ };
295
+ command.printUpgradePlan(plan);
296
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('MEDIUM'));
297
+ });
298
+ it('should show breaking changes count', () => {
299
+ const plan = {
300
+ currentVersion: '1.0.0',
301
+ targetVersion: '2.0.0',
302
+ estimatedRisk: 'high',
303
+ changes: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
304
+ breakingChanges: [{ type: 'modify', sourcePath: '/s', targetPath: '/t', description: 'breaking', breaking: true }],
305
+ };
306
+ command.printUpgradePlan(plan);
307
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Breaking Changes:'));
308
+ });
309
+ it('should show breaking indicator on changes', () => {
310
+ const plan = {
311
+ currentVersion: '1.0.0',
312
+ targetVersion: '2.0.0',
313
+ estimatedRisk: 'high',
314
+ changes: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'breaking change', breaking: true }],
315
+ breakingChanges: [{ type: 'add', sourcePath: '/s', targetPath: '/t', description: 'breaking change', breaking: true }],
316
+ };
317
+ command.printUpgradePlan(plan);
318
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('[BREAKING]'));
319
+ });
320
+ });
321
+ describe('getChangeIcon', () => {
322
+ it('should return + for add', () => {
323
+ expect(command.getChangeIcon('add')).toBe('+');
324
+ });
325
+ it('should return ~ for modify', () => {
326
+ expect(command.getChangeIcon('modify')).toBe('~');
327
+ });
328
+ it('should return - for remove', () => {
329
+ expect(command.getChangeIcon('remove')).toBe('-');
330
+ });
331
+ it('should return » for migrate', () => {
332
+ expect(command.getChangeIcon('migrate')).toBe('»');
333
+ });
334
+ it('should return ? for unknown type', () => {
335
+ expect(command.getChangeIcon('unknown')).toBe('?');
336
+ });
337
+ });
338
+ describe('getRiskColor', () => {
339
+ it('should return high for high risk', () => {
340
+ expect(command.getRiskColor('high')).toBe('high');
341
+ });
342
+ it('should return medium for medium risk', () => {
343
+ expect(command.getRiskColor('medium')).toBe('medium');
344
+ });
345
+ it('should return low for unknown risk', () => {
346
+ expect(command.getRiskColor('unknown')).toBe('low');
347
+ });
348
+ it('should return low for empty string', () => {
349
+ expect(command.getRiskColor('')).toBe('low');
350
+ });
351
+ });
352
+ describe('findCorePath', () => {
353
+ it('should return satellite path', () => {
354
+ expect(command.findCorePath('/some/path')).toBe('/some/path');
355
+ });
356
+ });
357
+ describe('parseDryRun', () => {
358
+ it('should return true', () => {
359
+ expect(command.parseDryRun()).toBe(true);
360
+ });
361
+ });
362
+ describe('parseForce', () => {
363
+ it('should return true', () => {
364
+ expect(command.parseForce()).toBe(true);
365
+ });
366
+ });
367
+ describe('parseCore', () => {
368
+ it('should return the value', () => {
369
+ expect(command.parseCore('/custom/path')).toBe('/custom/path');
370
+ });
371
+ });
372
+ describe('parseReport', () => {
373
+ it('should return true', () => {
374
+ expect(command.parseReport()).toBe(true);
375
+ });
376
+ });
377
+ });
378
+ //# sourceMappingURL=upgrade.command.spec.js.map