@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 @@
1
+ {"version":3,"file":"dora-calculator.spec.js","sourceRoot":"","sources":["../../../src/core/metrics/dora-calculator.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ export interface GitCommit {
2
+ hash: string;
3
+ date: string;
4
+ subject: string;
5
+ parents: string[];
6
+ isMerge: boolean;
7
+ }
8
+ export interface GitLogOptions {
9
+ cwd: string;
10
+ sinceDays?: number;
11
+ maxCount?: number;
12
+ }
13
+ export declare function readGitLog(opts: GitLogOptions): Promise<GitCommit[]>;
14
+ export declare function isGitRepo(cwd: string): Promise<boolean>;
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.readGitLog = readGitLog;
4
+ exports.isGitRepo = isGitRepo;
5
+ const child_process_1 = require("child_process");
6
+ const util_1 = require("util");
7
+ const execAsync = (0, util_1.promisify)(child_process_1.exec);
8
+ async function readGitLog(opts) {
9
+ const { cwd, sinceDays = 90, maxCount = 500 } = opts;
10
+ const since = `${sinceDays} days ago`;
11
+ const format = '%H|%aI|%s|%P';
12
+ const { stdout } = await execAsync(`git log --format="${format}" --since="${since}" --max-count=${maxCount}`, { cwd });
13
+ if (!stdout.trim())
14
+ return [];
15
+ return stdout
16
+ .trim()
17
+ .split('\n')
18
+ .map(line => {
19
+ const [hash, date, subject, parentsRaw] = line.split('|');
20
+ const parents = parentsRaw ? parentsRaw.trim().split(/\s+/).filter(Boolean) : [];
21
+ return {
22
+ hash: hash.trim(),
23
+ date: date.trim(),
24
+ subject: subject.trim(),
25
+ parents,
26
+ isMerge: parents.length > 1,
27
+ };
28
+ });
29
+ }
30
+ async function isGitRepo(cwd) {
31
+ try {
32
+ await execAsync('git rev-parse --git-dir', { cwd });
33
+ return true;
34
+ }
35
+ catch {
36
+ return false;
37
+ }
38
+ }
39
+ //# sourceMappingURL=git-log-reader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git-log-reader.js","sourceRoot":"","sources":["../../../src/core/metrics/git-log-reader.ts"],"names":[],"mappings":";;AAiCA,gCA4BC;AAKD,8BAOC;AApED,iDAAqC;AACrC,+BAAiC;AAEjC,MAAM,SAAS,GAAG,IAAA,gBAAS,EAAC,oBAAI,CAAC,CAAC;AAyB3B,KAAK,UAAU,UAAU,CAAC,IAAmB;IAClD,MAAM,EAAE,GAAG,EAAE,SAAS,GAAG,EAAE,EAAE,QAAQ,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC;IAErD,MAAM,KAAK,GAAG,GAAG,SAAS,WAAW,CAAC;IAEtC,MAAM,MAAM,GAAG,cAAc,CAAC;IAE9B,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,SAAS,CAChC,qBAAqB,MAAM,cAAc,KAAK,iBAAiB,QAAQ,EAAE,EACzE,EAAE,GAAG,EAAE,CACR,CAAC;IAEF,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;QAAE,OAAO,EAAE,CAAC;IAE9B,OAAO,MAAM;SACV,IAAI,EAAE;SACN,KAAK,CAAC,IAAI,CAAC;SACX,GAAG,CAAC,IAAI,CAAC,EAAE;QACV,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1D,MAAM,OAAO,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACjF,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE;YACjB,OAAO,EAAE,OAAO,CAAC,IAAI,EAAE;YACvB,OAAO;YACP,OAAO,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC;SAC5B,CAAC;IACJ,CAAC,CAAC,CAAC;AACP,CAAC;AAKM,KAAK,UAAU,SAAS,CAAC,GAAW;IACzC,IAAI,CAAC;QACH,MAAM,SAAS,CAAC,yBAAyB,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const execAsync = jest.fn();
4
+ jest.mock('child_process', () => {
5
+ const { promisify: prom } = require('util');
6
+ const exec = jest.fn();
7
+ exec[prom.custom] = execAsync;
8
+ return { exec };
9
+ });
10
+ const git_log_reader_1 = require("./git-log-reader");
11
+ function mockStdout(stdout) {
12
+ execAsync.mockResolvedValue({ stdout, stderr: '' });
13
+ }
14
+ function mockError(message) {
15
+ execAsync.mockRejectedValue(new Error(message));
16
+ }
17
+ beforeEach(() => jest.clearAllMocks());
18
+ describe('readGitLog', () => {
19
+ it('returns empty array when stdout is blank', async () => {
20
+ mockStdout(' ');
21
+ expect(await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' })).toEqual([]);
22
+ });
23
+ it('parses a single commit correctly', async () => {
24
+ const iso = '2026-06-01T10:00:00+00:00';
25
+ mockStdout(`abc123|${iso}|feat: add login|parent1`);
26
+ const [commit] = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
27
+ expect(commit).toMatchObject({
28
+ hash: 'abc123',
29
+ date: iso,
30
+ subject: 'feat: add login',
31
+ parents: ['parent1'],
32
+ isMerge: false,
33
+ });
34
+ });
35
+ it('parses multiple commits', async () => {
36
+ const iso = '2026-06-01T10:00:00+00:00';
37
+ mockStdout([
38
+ `h1|${iso}|feat: a|p1`,
39
+ `h2|${iso}|fix: b|p2`,
40
+ `h3|${iso}|chore: c|p3`,
41
+ ].join('\n'));
42
+ const result = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
43
+ expect(result).toHaveLength(3);
44
+ expect(result[1].hash).toBe('h2');
45
+ });
46
+ it('marks isMerge=true for two-parent commits', async () => {
47
+ const iso = '2026-06-01T10:00:00+00:00';
48
+ mockStdout(`merge1|${iso}|Merge branch feature|mainHash featureHash`);
49
+ const [commit] = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
50
+ expect(commit.isMerge).toBe(true);
51
+ expect(commit.parents).toEqual(['mainHash', 'featureHash']);
52
+ });
53
+ it('marks isMerge=false for single-parent commit', async () => {
54
+ const iso = '2026-06-01T10:00:00+00:00';
55
+ mockStdout(`c1|${iso}|feat: x|parentOnly`);
56
+ const [commit] = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
57
+ expect(commit.isMerge).toBe(false);
58
+ });
59
+ it('handles initial commit with no parents', async () => {
60
+ const iso = '2026-06-01T10:00:00+00:00';
61
+ mockStdout(`root|${iso}|initial commit|`);
62
+ const [commit] = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
63
+ expect(commit.parents).toEqual([]);
64
+ expect(commit.isMerge).toBe(false);
65
+ });
66
+ it('trims whitespace from all fields', async () => {
67
+ const iso = '2026-06-01T10:00:00+00:00';
68
+ mockStdout(` abc | ${iso} | feat: trimmed | p1 `);
69
+ const [commit] = await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
70
+ expect(commit.hash).toBe('abc');
71
+ expect(commit.subject).toBe('feat: trimmed');
72
+ });
73
+ it('passes --since flag with sinceDays', async () => {
74
+ mockStdout('');
75
+ await (0, git_log_reader_1.readGitLog)({ cwd: '/repo', sinceDays: 30 });
76
+ const cmd = execAsync.mock.calls[0][0];
77
+ expect(cmd).toContain('--since="30 days ago"');
78
+ });
79
+ it('passes --max-count flag', async () => {
80
+ mockStdout('');
81
+ await (0, git_log_reader_1.readGitLog)({ cwd: '/repo', maxCount: 100 });
82
+ const cmd = execAsync.mock.calls[0][0];
83
+ expect(cmd).toContain('--max-count=100');
84
+ });
85
+ it('uses provided cwd in exec options', async () => {
86
+ mockStdout('');
87
+ await (0, git_log_reader_1.readGitLog)({ cwd: '/my/project' });
88
+ expect(execAsync.mock.calls[0][1]).toMatchObject({ cwd: '/my/project' });
89
+ });
90
+ it('defaults sinceDays=90 and maxCount=500', async () => {
91
+ mockStdout('');
92
+ await (0, git_log_reader_1.readGitLog)({ cwd: '/repo' });
93
+ const cmd = execAsync.mock.calls[0][0];
94
+ expect(cmd).toContain('--since="90 days ago"');
95
+ expect(cmd).toContain('--max-count=500');
96
+ });
97
+ });
98
+ describe('isGitRepo', () => {
99
+ it('returns true when git rev-parse succeeds', async () => {
100
+ execAsync.mockResolvedValue({ stdout: '.git', stderr: '' });
101
+ expect(await (0, git_log_reader_1.isGitRepo)('/repo')).toBe(true);
102
+ });
103
+ it('returns false when exec throws', async () => {
104
+ mockError('not a git repository');
105
+ expect(await (0, git_log_reader_1.isGitRepo)('/not-a-repo')).toBe(false);
106
+ });
107
+ });
108
+ //# sourceMappingURL=git-log-reader.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git-log-reader.spec.js","sourceRoot":"","sources":["../../../src/core/metrics/git-log-reader.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const command_watcher_1 = require("./command-watcher");
4
+ const command_executor_1 = require("../../infrastructure/cli/command-executor");
5
+ jest.mock('../../infrastructure/cli/command-executor', () => ({
6
+ commandExecutor: {
7
+ checkTool: jest.fn(),
8
+ execute: jest.fn(),
9
+ },
10
+ }));
11
+ const mockedExecutor = command_executor_1.commandExecutor;
12
+ describe('CommandWatcher', () => {
13
+ let watcher;
14
+ beforeEach(() => {
15
+ jest.clearAllMocks();
16
+ watcher = new command_watcher_1.CommandWatcher();
17
+ mockedExecutor.checkTool.mockResolvedValue({
18
+ name: 'node',
19
+ available: true,
20
+ version: 'v1',
21
+ });
22
+ });
23
+ it('records successful command traces with platform checks', async () => {
24
+ mockedExecutor.execute.mockResolvedValue({
25
+ command: 'node --version',
26
+ exitCode: 0,
27
+ success: true,
28
+ stdout: 'v1',
29
+ stderr: '',
30
+ });
31
+ const trace = await watcher.executeWithTrace('node --version', '/repo', {
32
+ name: 'node',
33
+ command: 'node --version',
34
+ });
35
+ expect(trace.success).toBe(true);
36
+ expect(trace.platformCheck?.available).toBe(true);
37
+ expect(watcher.getLastTrace()).toEqual(trace);
38
+ expect(watcher.getSuccessfulTraces()).toHaveLength(1);
39
+ expect(watcher.getFailedTraces()).toHaveLength(0);
40
+ });
41
+ it('records failed command traces and clears history', async () => {
42
+ mockedExecutor.execute.mockResolvedValue({
43
+ command: 'bad',
44
+ exitCode: 1,
45
+ success: false,
46
+ stdout: '',
47
+ stderr: 'failed',
48
+ });
49
+ const trace = await watcher.executeWithTrace('bad');
50
+ expect(trace.success).toBe(false);
51
+ expect(watcher.getFailedTraces()).toHaveLength(1);
52
+ watcher.clearTraces();
53
+ expect(watcher.getTraces()).toEqual([]);
54
+ });
55
+ it('records exception traces and rethrows', async () => {
56
+ mockedExecutor.execute.mockRejectedValue(new Error('boom'));
57
+ await expect(watcher.executeWithTrace('explode')).rejects.toThrow('boom');
58
+ expect(watcher.getLastTrace()?.success).toBe(false);
59
+ expect(watcher.getLastTrace()?.stderr).toBe('boom');
60
+ });
61
+ it('reports unavailable platform checks', async () => {
62
+ mockedExecutor.checkTool.mockResolvedValue({
63
+ name: 'gh',
64
+ available: false,
65
+ installHint: 'install gh',
66
+ });
67
+ mockedExecutor.execute.mockResolvedValue({
68
+ command: 'gh --version',
69
+ exitCode: 0,
70
+ success: true,
71
+ stdout: '',
72
+ stderr: '',
73
+ });
74
+ const trace = await watcher.executeWithTrace('gh --version', undefined, {
75
+ name: 'gh',
76
+ command: 'gh --version',
77
+ });
78
+ expect(trace.platformCheck).toEqual({
79
+ name: 'gh',
80
+ available: false,
81
+ version: undefined,
82
+ });
83
+ await expect(watcher.checkPlatformAndReport('gh', 'gh --version')).resolves.toBe(false);
84
+ });
85
+ it('prints summaries for successful and failed traces', async () => {
86
+ mockedExecutor.execute
87
+ .mockResolvedValueOnce({ command: 'ok', exitCode: 0, success: true, stdout: '', stderr: '' })
88
+ .mockResolvedValueOnce({ command: 'bad', exitCode: 2, success: false, stdout: '', stderr: 'nope' });
89
+ const logSpy = jest.spyOn(console, 'log').mockImplementation(() => { });
90
+ await watcher.executeWithTrace('ok');
91
+ await watcher.executeWithTrace('bad');
92
+ watcher.printSummary();
93
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('[CMD-'));
94
+ logSpy.mockRestore();
95
+ });
96
+ });
97
+ describe('CommandBuilder', () => {
98
+ beforeEach(() => {
99
+ jest.clearAllMocks();
100
+ });
101
+ it('builds commands fluently and executes them with a fresh watcher', async () => {
102
+ mockedExecutor.execute.mockResolvedValue({
103
+ command: 'npm test -- --runInBand',
104
+ exitCode: 0,
105
+ success: true,
106
+ stdout: 'ok',
107
+ stderr: '',
108
+ });
109
+ const builder = new command_watcher_1.CommandBuilder('npm')
110
+ .append('test')
111
+ .append('--')
112
+ .append('--runInBand')
113
+ .withCwd('/repo')
114
+ .disableTrace();
115
+ expect(builder.build()).toBe('npm test -- --runInBand');
116
+ await expect(builder.execute()).resolves.toMatchObject({
117
+ command: 'npm test -- --runInBand',
118
+ cwd: '/repo',
119
+ success: true,
120
+ });
121
+ });
122
+ });
123
+ //# sourceMappingURL=command-watcher.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-watcher.spec.js","sourceRoot":"","sources":["../../../src/core/observability/command-watcher.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,291 @@
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 error_reporter_1 = require("./error-reporter");
37
+ jest.mock('./structured-logger', () => ({
38
+ logger: {
39
+ startOperation: jest.fn(),
40
+ endOperation: jest.fn(),
41
+ error: jest.fn(),
42
+ info: jest.fn(),
43
+ warn: jest.fn(),
44
+ },
45
+ LogLevel: {
46
+ DEBUG: 'DEBUG',
47
+ INFO: 'INFO',
48
+ WARN: 'WARN',
49
+ ERROR: 'ERROR',
50
+ FATAL: 'FATAL',
51
+ },
52
+ }));
53
+ jest.mock('../errors', () => ({
54
+ isEvolithError: jest.fn(() => false),
55
+ getErrorContext: jest.fn(),
56
+ getErrorCode: jest.fn(),
57
+ EvolithError: class EvolithError extends Error {
58
+ constructor(message, code) {
59
+ super(message);
60
+ this.code = code;
61
+ this.name = 'EvolithError';
62
+ }
63
+ },
64
+ }));
65
+ const structured_logger_1 = require("./structured-logger");
66
+ const errors = __importStar(require("../errors"));
67
+ const mockIsEvolithError = errors.isEvolithError;
68
+ describe('ErrorReporter', () => {
69
+ let reporter;
70
+ beforeEach(() => {
71
+ jest.clearAllMocks();
72
+ mockIsEvolithError.mockReturnValue(false);
73
+ reporter = new error_reporter_1.ErrorReporter();
74
+ });
75
+ describe('startOperation', () => {
76
+ it('should start operation timing', () => {
77
+ reporter.startOperation('test-operation');
78
+ expect(structured_logger_1.logger.startOperation).toHaveBeenCalledWith('test-operation');
79
+ });
80
+ });
81
+ describe('report', () => {
82
+ it('should report standard Error', () => {
83
+ const error = new Error('Test error');
84
+ const context = { operation: 'test', command: 'evolith validate' };
85
+ const report = reporter.report(error, context);
86
+ expect(report.error.name).toBe('Error');
87
+ expect(report.error.message).toBe('Test error');
88
+ expect(report.operation).toBe('test');
89
+ expect(report.context).toEqual(context);
90
+ });
91
+ it('should report EvolithError with code', () => {
92
+ mockIsEvolithError.mockReturnValue(true);
93
+ const evolithError = new errors.EvolithError('Validation failed', 'GOV-01');
94
+ const report = reporter.report(evolithError, { operation: 'validate' });
95
+ expect(report.error.code).toBe('GOV-01');
96
+ expect(report.suggestion).toBeDefined();
97
+ });
98
+ it('should report unknown error type', () => {
99
+ const report = reporter.report('string error', { operation: 'test' });
100
+ expect(report.error.name).toBe('Unknown');
101
+ expect(report.error.message).toBe('string error');
102
+ });
103
+ it('should report error without context', () => {
104
+ const error = new Error('No context error');
105
+ const report = reporter.report(error);
106
+ expect(report.context).toEqual({});
107
+ expect(report.operation).toBeUndefined();
108
+ });
109
+ it('should include duration when operation was started', () => {
110
+ reporter.startOperation('timed-operation');
111
+ const error = new Error('Timed error');
112
+ const report = reporter.report(error, { operation: 'timed-operation' });
113
+ expect(report.durationMs).toBeGreaterThanOrEqual(0);
114
+ });
115
+ it('should emit report to logger', () => {
116
+ const error = new Error('Emit test');
117
+ reporter.report(error, { operation: 'emit-test' });
118
+ expect(structured_logger_1.logger.error).toHaveBeenCalled();
119
+ });
120
+ it('should log suggestion when present', () => {
121
+ mockIsEvolithError.mockReturnValue(true);
122
+ const evolithError = new errors.EvolithError('Config error', 'GOV-01');
123
+ reporter.report(evolithError);
124
+ expect(structured_logger_1.logger.info).toHaveBeenCalledWith(expect.stringContaining('Suggestion'));
125
+ });
126
+ });
127
+ describe('getReports', () => {
128
+ it('should return all reports', () => {
129
+ reporter.report(new Error('Error 1'));
130
+ reporter.report(new Error('Error 2'));
131
+ const reports = reporter.getReports();
132
+ expect(reports).toHaveLength(2);
133
+ });
134
+ it('should return a copy of reports', () => {
135
+ reporter.report(new Error('Error 1'));
136
+ const reports = reporter.getReports();
137
+ reports.length = 0;
138
+ expect(reporter.getReports()).toHaveLength(1);
139
+ });
140
+ });
141
+ describe('getLastReport', () => {
142
+ it('should return the last report', () => {
143
+ reporter.report(new Error('Error 1'));
144
+ reporter.report(new Error('Error 2'));
145
+ const last = reporter.getLastReport();
146
+ expect(last?.error.message).toBe('Error 2');
147
+ });
148
+ it('should return undefined when no reports', () => {
149
+ const last = reporter.getLastReport();
150
+ expect(last).toBeUndefined();
151
+ });
152
+ });
153
+ describe('clearReports', () => {
154
+ it('should clear all reports', () => {
155
+ reporter.report(new Error('Error 1'));
156
+ reporter.report(new Error('Error 2'));
157
+ reporter.clearReports();
158
+ expect(reporter.getReports()).toHaveLength(0);
159
+ });
160
+ });
161
+ describe('printSummary', () => {
162
+ let logSpy;
163
+ beforeEach(() => {
164
+ logSpy = jest.spyOn(console, 'log').mockImplementation(() => { });
165
+ });
166
+ afterEach(() => {
167
+ logSpy.mockRestore();
168
+ });
169
+ it('should print no errors message when empty', () => {
170
+ reporter.printSummary();
171
+ expect(structured_logger_1.logger.info).toHaveBeenCalledWith('No errors reported.');
172
+ });
173
+ it('should print error summary', () => {
174
+ reporter.report(new Error('Test error'), { operation: 'test' });
175
+ reporter.printSummary();
176
+ expect(structured_logger_1.logger.info).toHaveBeenCalledWith('Error Summary: 1 error(s)');
177
+ });
178
+ it('should print error details', () => {
179
+ mockIsEvolithError.mockReturnValue(true);
180
+ const evolithError = new errors.EvolithError('Config error', 'GOV-01');
181
+ reporter.report(evolithError, { operation: 'validate' });
182
+ reporter.printSummary();
183
+ expect(logSpy).toHaveBeenCalledWith(expect.stringContaining('Config error'));
184
+ });
185
+ });
186
+ describe('getSuggestionForCode', () => {
187
+ it('should return suggestion for PLATFORM_NOT_FOUND', () => {
188
+ mockIsEvolithError.mockReturnValue(true);
189
+ const evolithError = new errors.EvolithError('test', 'PLATFORM_NOT_FOUND');
190
+ const report = reporter.report(evolithError);
191
+ expect(report.suggestion).toContain('Install');
192
+ });
193
+ it('should return suggestion for PHASE_TRANSITION_ERROR', () => {
194
+ mockIsEvolithError.mockReturnValue(true);
195
+ const evolithError = new errors.EvolithError('test', 'PHASE_TRANSITION_ERROR');
196
+ const report = reporter.report(evolithError);
197
+ expect(report.suggestion).toContain('transitioning');
198
+ });
199
+ it('should return suggestion for CATALOG_LOAD_ERROR', () => {
200
+ mockIsEvolithError.mockReturnValue(true);
201
+ const evolithError = new errors.EvolithError('test', 'CATALOG_LOAD_ERROR');
202
+ const report = reporter.report(evolithError);
203
+ expect(report.suggestion).toContain('catalog');
204
+ });
205
+ it('should return suggestion for TOOL_VALIDATION_ERROR', () => {
206
+ mockIsEvolithError.mockReturnValue(true);
207
+ const evolithError = new errors.EvolithError('test', 'TOOL_VALIDATION_ERROR');
208
+ const report = reporter.report(evolithError);
209
+ expect(report.suggestion).toContain('supported');
210
+ });
211
+ it('should return suggestion for COMMAND_EXECUTION_ERROR', () => {
212
+ mockIsEvolithError.mockReturnValue(true);
213
+ const evolithError = new errors.EvolithError('test', 'COMMAND_EXECUTION_ERROR');
214
+ const report = reporter.report(evolithError);
215
+ expect(report.suggestion).toContain('syntax');
216
+ });
217
+ it('should return suggestion for VALIDATION_ERROR', () => {
218
+ mockIsEvolithError.mockReturnValue(true);
219
+ const evolithError = new errors.EvolithError('test', 'VALIDATION_ERROR');
220
+ const report = reporter.report(evolithError);
221
+ expect(report.suggestion).toContain('Review');
222
+ });
223
+ it('should return generic suggestion for unknown code', () => {
224
+ mockIsEvolithError.mockReturnValue(true);
225
+ const evolithError = new errors.EvolithError('test', 'UNKNOWN_CODE');
226
+ const report = reporter.report(evolithError);
227
+ expect(report.suggestion).toContain('details');
228
+ });
229
+ });
230
+ describe('getSuggestionForError', () => {
231
+ it('should return suggestion for ENOENT errors', () => {
232
+ const enoentError = new Error('ENOENT: no such file');
233
+ const report = reporter.report(enoentError);
234
+ expect(report.suggestion).toContain('not found');
235
+ });
236
+ it('should return suggestion for EACCES errors', () => {
237
+ const eaccesError = new Error('EACCES: permission denied');
238
+ const report = reporter.report(eaccesError);
239
+ expect(report.suggestion).toContain('Permission denied');
240
+ });
241
+ it('should return suggestion for ENOEXEC errors', () => {
242
+ const enoexecError = new Error('ENOEXEC: not executable');
243
+ const report = reporter.report(enoexecError);
244
+ expect(report.suggestion).toContain('Install');
245
+ });
246
+ it('should return generic suggestion for other errors', () => {
247
+ const genericError = new Error('Something went wrong');
248
+ const report = reporter.report(genericError);
249
+ expect(report.suggestion).toContain('unexpected');
250
+ });
251
+ });
252
+ describe('generateId', () => {
253
+ it('should generate unique IDs', () => {
254
+ const report1 = reporter.report(new Error('Error 1'));
255
+ const report2 = reporter.report(new Error('Error 2'));
256
+ expect(report1.id).not.toBe(report2.id);
257
+ });
258
+ it('should generate IDs with ERR- prefix', () => {
259
+ const report = reporter.report(new Error('Test'));
260
+ expect(report.id).toMatch(/^ERR-/);
261
+ });
262
+ });
263
+ });
264
+ describe('OperationContext', () => {
265
+ beforeEach(() => {
266
+ error_reporter_1.OperationContext.clear();
267
+ });
268
+ it('should set and get values', () => {
269
+ error_reporter_1.OperationContext.set('key', 'value');
270
+ expect(error_reporter_1.OperationContext.get('key')).toBe('value');
271
+ });
272
+ it('should return undefined for missing keys', () => {
273
+ expect(error_reporter_1.OperationContext.get('missing')).toBeUndefined();
274
+ });
275
+ it('should clear all values', () => {
276
+ error_reporter_1.OperationContext.set('key1', 'value1');
277
+ error_reporter_1.OperationContext.set('key2', 'value2');
278
+ error_reporter_1.OperationContext.clear();
279
+ expect(error_reporter_1.OperationContext.get('key1')).toBeUndefined();
280
+ expect(error_reporter_1.OperationContext.get('key2')).toBeUndefined();
281
+ });
282
+ it('should return copy of all values', () => {
283
+ error_reporter_1.OperationContext.set('key1', 'value1');
284
+ error_reporter_1.OperationContext.set('key2', 'value2');
285
+ const all = error_reporter_1.OperationContext.getAll();
286
+ expect(all).toEqual({ key1: 'value1', key2: 'value2' });
287
+ all.key1 = 'modified';
288
+ expect(error_reporter_1.OperationContext.get('key1')).toBe('value1');
289
+ });
290
+ });
291
+ //# sourceMappingURL=error-reporter.spec.js.map