@girardelli/architect 5.0.0 → 8.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 (335) hide show
  1. package/dist/{cli.d.ts → src/adapters/cli.d.ts} +1 -2
  2. package/dist/{cli.js → src/adapters/cli.js} +191 -213
  3. package/dist/src/adapters/cli.js.map +1 -0
  4. package/dist/src/adapters/github-action.d.ts +9 -0
  5. package/dist/src/adapters/github-action.js +94 -0
  6. package/dist/src/adapters/github-action.js.map +1 -0
  7. package/dist/src/adapters/html-reporter/scripts.d.ts +5 -0
  8. package/dist/src/adapters/html-reporter/scripts.js +400 -0
  9. package/dist/src/adapters/html-reporter/scripts.js.map +1 -0
  10. package/dist/src/adapters/html-reporter/sections/agents.d.ts +2 -0
  11. package/dist/src/adapters/html-reporter/sections/agents.js +260 -0
  12. package/dist/src/adapters/html-reporter/sections/agents.js.map +1 -0
  13. package/dist/src/adapters/html-reporter/sections/anti-patterns.d.ts +13 -0
  14. package/dist/src/adapters/html-reporter/sections/anti-patterns.js +64 -0
  15. package/dist/src/adapters/html-reporter/sections/anti-patterns.js.map +1 -0
  16. package/dist/src/adapters/html-reporter/sections/header.d.ts +3 -0
  17. package/dist/src/adapters/html-reporter/sections/header.js +30 -0
  18. package/dist/src/adapters/html-reporter/sections/header.js.map +1 -0
  19. package/dist/src/adapters/html-reporter/sections/layers.d.ts +9 -0
  20. package/dist/src/adapters/html-reporter/sections/layers.js +143 -0
  21. package/dist/src/adapters/html-reporter/sections/layers.js.map +1 -0
  22. package/dist/src/adapters/html-reporter/sections/overview.d.ts +2 -0
  23. package/dist/src/adapters/html-reporter/sections/overview.js +58 -0
  24. package/dist/src/adapters/html-reporter/sections/overview.js.map +1 -0
  25. package/dist/src/adapters/html-reporter/sections/refactoring-plan.d.ts +3 -0
  26. package/dist/src/adapters/html-reporter/sections/refactoring-plan.js +151 -0
  27. package/dist/src/adapters/html-reporter/sections/refactoring-plan.js.map +1 -0
  28. package/dist/src/adapters/html-reporter/sections/score.d.ts +7 -0
  29. package/dist/src/adapters/html-reporter/sections/score.js +70 -0
  30. package/dist/src/adapters/html-reporter/sections/score.js.map +1 -0
  31. package/dist/src/adapters/html-reporter/sections/suggestions.d.ts +7 -0
  32. package/dist/src/adapters/html-reporter/sections/suggestions.js +34 -0
  33. package/dist/src/adapters/html-reporter/sections/suggestions.js.map +1 -0
  34. package/dist/src/adapters/html-reporter/styles.d.ts +1 -0
  35. package/dist/src/adapters/html-reporter/styles.js +526 -0
  36. package/dist/src/adapters/html-reporter/styles.js.map +1 -0
  37. package/dist/src/adapters/html-reporter/utils_adapters.d.ts +20 -0
  38. package/dist/src/adapters/html-reporter/utils_adapters.js +32 -0
  39. package/dist/src/adapters/html-reporter/utils_adapters.js.map +1 -0
  40. package/dist/src/adapters/html-reporter/utils_sections.d.ts +7 -0
  41. package/dist/src/adapters/html-reporter/utils_sections.js +58 -0
  42. package/dist/src/adapters/html-reporter/utils_sections.js.map +1 -0
  43. package/dist/src/adapters/html-reporter.d.ts +10 -0
  44. package/dist/src/adapters/html-reporter.js +97 -0
  45. package/dist/src/adapters/html-reporter.js.map +1 -0
  46. package/dist/src/adapters/progress-logger.d.ts +55 -0
  47. package/dist/src/adapters/progress-logger.js +200 -0
  48. package/dist/src/adapters/progress-logger.js.map +1 -0
  49. package/dist/{refactor-reporter.d.ts → src/adapters/refactor-reporter.d.ts} +1 -2
  50. package/dist/{refactor-reporter.js → src/adapters/refactor-reporter.js} +1 -1
  51. package/dist/src/adapters/refactor-reporter.js.map +1 -0
  52. package/dist/{reporter.d.ts → src/adapters/reporter.d.ts} +1 -2
  53. package/dist/src/adapters/reporter.js.map +1 -0
  54. package/dist/src/core/GenesisTerminal.d.ts +8 -0
  55. package/dist/src/core/GenesisTerminal.js +105 -0
  56. package/dist/src/core/GenesisTerminal.js.map +1 -0
  57. package/dist/{index.d.ts → src/core/architect.d.ts} +4 -18
  58. package/dist/{index.js → src/core/architect.js} +22 -21
  59. package/dist/src/core/architect.js.map +1 -0
  60. package/dist/tests/architect-adapter-enrichment.test.d.ts +1 -0
  61. package/dist/tests/architect-adapter-enrichment.test.js +11 -0
  62. package/dist/tests/architect-adapter-enrichment.test.js.map +1 -0
  63. package/dist/tests/github-action.test.d.ts +1 -0
  64. package/dist/tests/github-action.test.js +92 -0
  65. package/dist/tests/github-action.test.js.map +1 -0
  66. package/package.json +15 -65
  67. package/src/adapters/cli.ts +492 -0
  68. package/src/adapters/github-action.ts +109 -0
  69. package/src/adapters/html-reporter/scripts.ts +402 -0
  70. package/src/adapters/html-reporter/sections/agents.ts +267 -0
  71. package/src/adapters/html-reporter/sections/anti-patterns.ts +81 -0
  72. package/src/adapters/html-reporter/sections/header.ts +35 -0
  73. package/src/adapters/html-reporter/sections/layers.ts +165 -0
  74. package/src/adapters/html-reporter/sections/overview.ts +64 -0
  75. package/src/adapters/html-reporter/sections/refactoring-plan.ts +166 -0
  76. package/src/adapters/html-reporter/sections/score.ts +80 -0
  77. package/src/adapters/html-reporter/sections/suggestions.ts +39 -0
  78. package/src/adapters/html-reporter/styles.ts +525 -0
  79. package/src/adapters/html-reporter/utils_adapters.ts +39 -0
  80. package/src/adapters/html-reporter/utils_sections.ts +55 -0
  81. package/src/adapters/html-reporter.ts +102 -0
  82. package/src/adapters/progress-logger.ts +236 -0
  83. package/src/{refactor-reporter.ts → adapters/refactor-reporter.ts} +2 -2
  84. package/src/{reporter.ts → adapters/reporter.ts} +1 -1
  85. package/src/core/GenesisTerminal.ts +127 -0
  86. package/src/{index.ts → core/architect.ts} +27 -45
  87. package/tests/github-action.test.ts +109 -0
  88. package/tsconfig.json +12 -19
  89. package/CONTRIBUTING.md +0 -140
  90. package/LICENSE +0 -21
  91. package/PROJECT_STRUCTURE.txt +0 -168
  92. package/README.md +0 -257
  93. package/architect-run.sh +0 -431
  94. package/assets/banner-v3.html +0 -561
  95. package/dist/agent-generator/context-enricher.d.ts +0 -58
  96. package/dist/agent-generator/context-enricher.d.ts.map +0 -1
  97. package/dist/agent-generator/context-enricher.js +0 -613
  98. package/dist/agent-generator/context-enricher.js.map +0 -1
  99. package/dist/agent-generator/domain-inferrer.d.ts +0 -52
  100. package/dist/agent-generator/domain-inferrer.d.ts.map +0 -1
  101. package/dist/agent-generator/domain-inferrer.js +0 -585
  102. package/dist/agent-generator/domain-inferrer.js.map +0 -1
  103. package/dist/agent-generator/framework-detector.d.ts +0 -40
  104. package/dist/agent-generator/framework-detector.d.ts.map +0 -1
  105. package/dist/agent-generator/framework-detector.js +0 -611
  106. package/dist/agent-generator/framework-detector.js.map +0 -1
  107. package/dist/agent-generator/index.d.ts +0 -47
  108. package/dist/agent-generator/index.d.ts.map +0 -1
  109. package/dist/agent-generator/index.js +0 -545
  110. package/dist/agent-generator/index.js.map +0 -1
  111. package/dist/agent-generator/stack-detector.d.ts +0 -14
  112. package/dist/agent-generator/stack-detector.d.ts.map +0 -1
  113. package/dist/agent-generator/stack-detector.js +0 -124
  114. package/dist/agent-generator/stack-detector.js.map +0 -1
  115. package/dist/agent-generator/templates/core/agents.d.ts +0 -17
  116. package/dist/agent-generator/templates/core/agents.d.ts.map +0 -1
  117. package/dist/agent-generator/templates/core/agents.js +0 -1256
  118. package/dist/agent-generator/templates/core/agents.js.map +0 -1
  119. package/dist/agent-generator/templates/core/architecture-rules.d.ts +0 -7
  120. package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
  121. package/dist/agent-generator/templates/core/architecture-rules.js +0 -274
  122. package/dist/agent-generator/templates/core/architecture-rules.js.map +0 -1
  123. package/dist/agent-generator/templates/core/general-rules.d.ts +0 -8
  124. package/dist/agent-generator/templates/core/general-rules.d.ts.map +0 -1
  125. package/dist/agent-generator/templates/core/general-rules.js +0 -301
  126. package/dist/agent-generator/templates/core/general-rules.js.map +0 -1
  127. package/dist/agent-generator/templates/core/hooks-generator.d.ts +0 -21
  128. package/dist/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
  129. package/dist/agent-generator/templates/core/hooks-generator.js +0 -233
  130. package/dist/agent-generator/templates/core/hooks-generator.js.map +0 -1
  131. package/dist/agent-generator/templates/core/index-md.d.ts +0 -7
  132. package/dist/agent-generator/templates/core/index-md.d.ts.map +0 -1
  133. package/dist/agent-generator/templates/core/index-md.js +0 -246
  134. package/dist/agent-generator/templates/core/index-md.js.map +0 -1
  135. package/dist/agent-generator/templates/core/orchestrator.d.ts +0 -8
  136. package/dist/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
  137. package/dist/agent-generator/templates/core/orchestrator.js +0 -422
  138. package/dist/agent-generator/templates/core/orchestrator.js.map +0 -1
  139. package/dist/agent-generator/templates/core/preflight.d.ts +0 -8
  140. package/dist/agent-generator/templates/core/preflight.d.ts.map +0 -1
  141. package/dist/agent-generator/templates/core/preflight.js +0 -213
  142. package/dist/agent-generator/templates/core/preflight.js.map +0 -1
  143. package/dist/agent-generator/templates/core/quality-gates.d.ts +0 -11
  144. package/dist/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
  145. package/dist/agent-generator/templates/core/quality-gates.js +0 -254
  146. package/dist/agent-generator/templates/core/quality-gates.js.map +0 -1
  147. package/dist/agent-generator/templates/core/security-rules.d.ts +0 -7
  148. package/dist/agent-generator/templates/core/security-rules.d.ts.map +0 -1
  149. package/dist/agent-generator/templates/core/security-rules.js +0 -528
  150. package/dist/agent-generator/templates/core/security-rules.js.map +0 -1
  151. package/dist/agent-generator/templates/core/skills-generator.d.ts +0 -19
  152. package/dist/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
  153. package/dist/agent-generator/templates/core/skills-generator.js +0 -546
  154. package/dist/agent-generator/templates/core/skills-generator.js.map +0 -1
  155. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
  156. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
  157. package/dist/agent-generator/templates/core/workflow-fix-bug.js +0 -237
  158. package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
  159. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
  160. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
  161. package/dist/agent-generator/templates/core/workflow-new-feature.js +0 -321
  162. package/dist/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
  163. package/dist/agent-generator/templates/core/workflow-review.d.ts +0 -7
  164. package/dist/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
  165. package/dist/agent-generator/templates/core/workflow-review.js +0 -104
  166. package/dist/agent-generator/templates/core/workflow-review.js.map +0 -1
  167. package/dist/agent-generator/templates/domain/index.d.ts +0 -22
  168. package/dist/agent-generator/templates/domain/index.d.ts.map +0 -1
  169. package/dist/agent-generator/templates/domain/index.js +0 -1176
  170. package/dist/agent-generator/templates/domain/index.js.map +0 -1
  171. package/dist/agent-generator/templates/stack/index.d.ts +0 -8
  172. package/dist/agent-generator/templates/stack/index.d.ts.map +0 -1
  173. package/dist/agent-generator/templates/stack/index.js +0 -695
  174. package/dist/agent-generator/templates/stack/index.js.map +0 -1
  175. package/dist/agent-generator/templates/template-helpers.d.ts +0 -75
  176. package/dist/agent-generator/templates/template-helpers.d.ts.map +0 -1
  177. package/dist/agent-generator/templates/template-helpers.js +0 -726
  178. package/dist/agent-generator/templates/template-helpers.js.map +0 -1
  179. package/dist/agent-generator/types.d.ts +0 -196
  180. package/dist/agent-generator/types.d.ts.map +0 -1
  181. package/dist/agent-generator/types.js +0 -27
  182. package/dist/agent-generator/types.js.map +0 -1
  183. package/dist/analyzer.d.ts +0 -38
  184. package/dist/analyzer.d.ts.map +0 -1
  185. package/dist/analyzer.js +0 -383
  186. package/dist/analyzer.js.map +0 -1
  187. package/dist/analyzers/forecast.d.ts +0 -85
  188. package/dist/analyzers/forecast.d.ts.map +0 -1
  189. package/dist/analyzers/forecast.js +0 -337
  190. package/dist/analyzers/forecast.js.map +0 -1
  191. package/dist/analyzers/git-cache.d.ts +0 -7
  192. package/dist/analyzers/git-cache.d.ts.map +0 -1
  193. package/dist/analyzers/git-cache.js +0 -41
  194. package/dist/analyzers/git-cache.js.map +0 -1
  195. package/dist/analyzers/git-history.d.ts +0 -113
  196. package/dist/analyzers/git-history.d.ts.map +0 -1
  197. package/dist/analyzers/git-history.js +0 -333
  198. package/dist/analyzers/git-history.js.map +0 -1
  199. package/dist/analyzers/index.d.ts +0 -10
  200. package/dist/analyzers/index.d.ts.map +0 -1
  201. package/dist/analyzers/index.js +0 -7
  202. package/dist/analyzers/index.js.map +0 -1
  203. package/dist/analyzers/temporal-scorer.d.ts +0 -72
  204. package/dist/analyzers/temporal-scorer.d.ts.map +0 -1
  205. package/dist/analyzers/temporal-scorer.js +0 -140
  206. package/dist/analyzers/temporal-scorer.js.map +0 -1
  207. package/dist/anti-patterns.d.ts +0 -24
  208. package/dist/anti-patterns.d.ts.map +0 -1
  209. package/dist/anti-patterns.js +0 -230
  210. package/dist/anti-patterns.js.map +0 -1
  211. package/dist/cli.d.ts.map +0 -1
  212. package/dist/cli.js.map +0 -1
  213. package/dist/config.d.ts +0 -12
  214. package/dist/config.d.ts.map +0 -1
  215. package/dist/config.js +0 -110
  216. package/dist/config.js.map +0 -1
  217. package/dist/diagram.d.ts +0 -9
  218. package/dist/diagram.d.ts.map +0 -1
  219. package/dist/diagram.js +0 -116
  220. package/dist/diagram.js.map +0 -1
  221. package/dist/html-reporter.d.ts +0 -47
  222. package/dist/html-reporter.d.ts.map +0 -1
  223. package/dist/html-reporter.js +0 -1747
  224. package/dist/html-reporter.js.map +0 -1
  225. package/dist/index.d.ts.map +0 -1
  226. package/dist/index.js.map +0 -1
  227. package/dist/project-summarizer.d.ts +0 -38
  228. package/dist/project-summarizer.d.ts.map +0 -1
  229. package/dist/project-summarizer.js +0 -463
  230. package/dist/project-summarizer.js.map +0 -1
  231. package/dist/refactor-engine.d.ts +0 -18
  232. package/dist/refactor-engine.d.ts.map +0 -1
  233. package/dist/refactor-engine.js +0 -86
  234. package/dist/refactor-engine.js.map +0 -1
  235. package/dist/refactor-reporter.d.ts.map +0 -1
  236. package/dist/refactor-reporter.js.map +0 -1
  237. package/dist/reporter.d.ts.map +0 -1
  238. package/dist/reporter.js.map +0 -1
  239. package/dist/rules/barrel-optimizer.d.ts +0 -13
  240. package/dist/rules/barrel-optimizer.d.ts.map +0 -1
  241. package/dist/rules/barrel-optimizer.js +0 -77
  242. package/dist/rules/barrel-optimizer.js.map +0 -1
  243. package/dist/rules/dead-code-detector.d.ts +0 -21
  244. package/dist/rules/dead-code-detector.d.ts.map +0 -1
  245. package/dist/rules/dead-code-detector.js +0 -117
  246. package/dist/rules/dead-code-detector.js.map +0 -1
  247. package/dist/rules/hub-splitter.d.ts +0 -13
  248. package/dist/rules/hub-splitter.d.ts.map +0 -1
  249. package/dist/rules/hub-splitter.js +0 -110
  250. package/dist/rules/hub-splitter.js.map +0 -1
  251. package/dist/rules/import-organizer.d.ts +0 -13
  252. package/dist/rules/import-organizer.d.ts.map +0 -1
  253. package/dist/rules/import-organizer.js +0 -85
  254. package/dist/rules/import-organizer.js.map +0 -1
  255. package/dist/rules/module-grouper.d.ts +0 -13
  256. package/dist/rules/module-grouper.d.ts.map +0 -1
  257. package/dist/rules/module-grouper.js +0 -110
  258. package/dist/rules/module-grouper.js.map +0 -1
  259. package/dist/scanner.d.ts +0 -31
  260. package/dist/scanner.d.ts.map +0 -1
  261. package/dist/scanner.js +0 -328
  262. package/dist/scanner.js.map +0 -1
  263. package/dist/scorer.d.ts +0 -27
  264. package/dist/scorer.d.ts.map +0 -1
  265. package/dist/scorer.js +0 -229
  266. package/dist/scorer.js.map +0 -1
  267. package/dist/types.d.ts +0 -186
  268. package/dist/types.d.ts.map +0 -1
  269. package/dist/types.js +0 -2
  270. package/dist/types.js.map +0 -1
  271. package/examples/sample-report.md +0 -207
  272. package/jest.config.js +0 -18
  273. package/src/agent-generator/context-enricher.ts +0 -672
  274. package/src/agent-generator/domain-inferrer.ts +0 -635
  275. package/src/agent-generator/framework-detector.ts +0 -669
  276. package/src/agent-generator/index.ts +0 -634
  277. package/src/agent-generator/stack-detector.ts +0 -115
  278. package/src/agent-generator/templates/core/agents.ts +0 -1296
  279. package/src/agent-generator/templates/core/architecture-rules.ts +0 -287
  280. package/src/agent-generator/templates/core/general-rules.ts +0 -306
  281. package/src/agent-generator/templates/core/hooks-generator.ts +0 -242
  282. package/src/agent-generator/templates/core/index-md.ts +0 -260
  283. package/src/agent-generator/templates/core/orchestrator.ts +0 -459
  284. package/src/agent-generator/templates/core/preflight.ts +0 -215
  285. package/src/agent-generator/templates/core/quality-gates.ts +0 -256
  286. package/src/agent-generator/templates/core/security-rules.ts +0 -543
  287. package/src/agent-generator/templates/core/skills-generator.ts +0 -585
  288. package/src/agent-generator/templates/core/workflow-fix-bug.ts +0 -239
  289. package/src/agent-generator/templates/core/workflow-new-feature.ts +0 -323
  290. package/src/agent-generator/templates/core/workflow-review.ts +0 -106
  291. package/src/agent-generator/templates/domain/index.ts +0 -1201
  292. package/src/agent-generator/templates/stack/index.ts +0 -705
  293. package/src/agent-generator/templates/template-helpers.ts +0 -776
  294. package/src/agent-generator/types.ts +0 -232
  295. package/src/analyzer.ts +0 -447
  296. package/src/analyzers/forecast.ts +0 -496
  297. package/src/analyzers/git-cache.ts +0 -52
  298. package/src/analyzers/git-history.ts +0 -488
  299. package/src/analyzers/index.ts +0 -33
  300. package/src/analyzers/temporal-scorer.ts +0 -227
  301. package/src/anti-patterns.ts +0 -287
  302. package/src/cli.ts +0 -517
  303. package/src/config.ts +0 -123
  304. package/src/diagram.ts +0 -144
  305. package/src/html-reporter.ts +0 -1830
  306. package/src/project-summarizer.ts +0 -521
  307. package/src/refactor-engine.ts +0 -117
  308. package/src/rules/barrel-optimizer.ts +0 -97
  309. package/src/rules/dead-code-detector.ts +0 -132
  310. package/src/rules/hub-splitter.ts +0 -123
  311. package/src/rules/import-organizer.ts +0 -98
  312. package/src/rules/module-grouper.ts +0 -124
  313. package/src/scanner.ts +0 -344
  314. package/src/scorer.ts +0 -254
  315. package/src/types.ts +0 -193
  316. package/tests/agent-generator.test.ts +0 -427
  317. package/tests/analyzers-integration.test.ts +0 -174
  318. package/tests/anti-patterns.test.ts +0 -94
  319. package/tests/context-enricher.test.ts +0 -971
  320. package/tests/fixtures/monorepo/package.json +0 -6
  321. package/tests/fixtures/monorepo/packages/app/package.json +0 -12
  322. package/tests/fixtures/monorepo/packages/app/src/index.ts +0 -6
  323. package/tests/fixtures/monorepo/packages/core/package.json +0 -7
  324. package/tests/fixtures/monorepo/packages/core/src/index.ts +0 -7
  325. package/tests/forecast.test.ts +0 -509
  326. package/tests/framework-detector.test.ts +0 -1172
  327. package/tests/git-history.test.ts +0 -254
  328. package/tests/monorepo-scan.test.ts +0 -170
  329. package/tests/scanner.test.ts +0 -54
  330. package/tests/scorer.test.ts +0 -674
  331. package/tests/stack-detector.test.ts +0 -241
  332. package/tests/template-generation.test.ts +0 -706
  333. package/tests/template-helpers.test.ts +0 -1152
  334. package/tests/temporal-scorer.test.ts +0 -307
  335. /package/dist/{reporter.js → src/adapters/reporter.js} +0 -0
package/src/types.ts DELETED
@@ -1,193 +0,0 @@
1
- export interface FileNode {
2
- path: string;
3
- name: string;
4
- type: 'file' | 'directory';
5
- extension?: string;
6
- lines?: number;
7
- language?: string;
8
- children?: FileNode[];
9
- imports?: string[];
10
- exports?: string[];
11
- }
12
-
13
- export interface DependencyEdge {
14
- from: string;
15
- to: string;
16
- type: 'import' | 'export' | 'inheritance' | 'composition';
17
- weight: number;
18
- }
19
-
20
- export interface Layer {
21
- name: 'API' | 'Service' | 'Data' | 'UI' | 'Infrastructure';
22
- files: string[];
23
- description: string;
24
- }
25
-
26
- export interface AntiPattern {
27
- name: string;
28
- severity: 'CRITICAL' | 'HIGH' | 'MEDIUM' | 'LOW';
29
- location: string;
30
- description: string;
31
- suggestion: string;
32
- affectedFiles?: string[];
33
- metrics?: Record<string, number | string>;
34
- }
35
-
36
- export interface ScoreComponent {
37
- name: string;
38
- score: number;
39
- maxScore: number;
40
- weight: number;
41
- explanation: string;
42
- }
43
-
44
- export interface ArchitectureScore {
45
- overall: number;
46
- components: ScoreComponent[];
47
- breakdown: {
48
- modularity: number;
49
- coupling: number;
50
- cohesion: number;
51
- layering: number;
52
- };
53
- }
54
-
55
- export interface WorkspaceInfo {
56
- name: string;
57
- path: string;
58
- relativePath: string;
59
- description: string;
60
- version: string;
61
- dependencies: Record<string, string>;
62
- devDependencies: Record<string, string>;
63
- bin?: Record<string, string>;
64
- main?: string;
65
- }
66
-
67
- export interface ProjectInfo {
68
- path: string;
69
- name: string;
70
- frameworks: string[];
71
- totalFiles: number;
72
- totalLines: number;
73
- primaryLanguages: string[];
74
- fileTree?: FileNode;
75
- workspaces?: WorkspaceInfo[];
76
- }
77
-
78
- export interface AnalysisReport {
79
- timestamp: string;
80
- projectInfo: ProjectInfo;
81
- score: ArchitectureScore;
82
- antiPatterns: AntiPattern[];
83
- layers: Layer[];
84
- dependencyGraph: {
85
- nodes: string[];
86
- edges: DependencyEdge[];
87
- };
88
- suggestions: {
89
- priority: 'CRITICAL' | 'HIGH' | 'MEDIUM' | 'LOW';
90
- title: string;
91
- description: string;
92
- impact: string;
93
- }[];
94
- diagram: {
95
- mermaid: string;
96
- type: 'component' | 'layer' | 'dependency';
97
- };
98
- projectSummary?: ProjectSummary;
99
- }
100
-
101
- export interface ProjectSummary {
102
- description: string;
103
- purpose: string;
104
- modules: { name: string; files: number; description: string }[];
105
- techStack: string[];
106
- entryPoints: string[];
107
- keywords: string[];
108
- }
109
-
110
- export interface ArchitectConfig {
111
- ignore?: string[];
112
- frameworks?: {
113
- detect?: boolean;
114
- };
115
- antiPatterns?: {
116
- godClass?: {
117
- linesThreshold?: number;
118
- methodsThreshold?: number;
119
- };
120
- shotgunSurgery?: {
121
- changePropagationThreshold?: number;
122
- };
123
- };
124
- score?: {
125
- modularity?: number;
126
- coupling?: number;
127
- cohesion?: number;
128
- layering?: number;
129
- };
130
- monorepo?: {
131
- enabled?: boolean;
132
- treatPackagesAsModules?: boolean;
133
- };
134
- }
135
-
136
- export interface ParsedImport {
137
- source: string;
138
- names: string[];
139
- isDefault: boolean;
140
- isNamespace: boolean;
141
- }
142
-
143
- // ── v2.0 Refactoring Types ──
144
-
145
- export interface RefactoringPlan {
146
- timestamp: string;
147
- projectPath: string;
148
- currentScore: ArchitectureScore;
149
- estimatedScoreAfter: { overall: number; breakdown: Record<string, number> };
150
- steps: RefactorStep[];
151
- totalOperations: number;
152
- tier1Steps: number;
153
- tier2Steps: number;
154
- }
155
-
156
- export interface RefactorStep {
157
- id: number;
158
- tier: 1 | 2;
159
- rule: string;
160
- priority: 'CRITICAL' | 'HIGH' | 'MEDIUM' | 'LOW';
161
- title: string;
162
- description: string;
163
- rationale: string;
164
- operations: FileOperation[];
165
- scoreImpact: { metric: string; before: number; after: number }[];
166
- codePreview?: string;
167
- }
168
-
169
- export interface FileOperation {
170
- type: 'CREATE' | 'MOVE' | 'MODIFY' | 'DELETE';
171
- path: string;
172
- newPath?: string;
173
- content?: string;
174
- diff?: string;
175
- description: string;
176
- }
177
-
178
- export interface CodeSymbol {
179
- name: string;
180
- type: 'function' | 'class' | 'variable' | 'import' | 'export';
181
- startLine: number;
182
- endLine: number;
183
- lines: number;
184
- dependencies: string[];
185
- usedBy: string[];
186
- }
187
-
188
- export interface RefactorRule {
189
- name: string;
190
- tier: 1 | 2;
191
- analyze(report: AnalysisReport, projectPath: string): RefactorStep[];
192
- }
193
-
@@ -1,427 +0,0 @@
1
- import { AgentGenerator } from '../src/agent-generator/index.js';
2
- import { AnalysisReport, RefactoringPlan } from '../src/types.js';
3
- import { existsSync, mkdirSync, writeFileSync, rmSync } from 'fs';
4
- import { join } from 'path';
5
-
6
- // ── Test Data Factories ──
7
-
8
- function makeReport(overrides: Partial<AnalysisReport> = {}): AnalysisReport {
9
- return {
10
- timestamp: new Date().toISOString(),
11
- projectInfo: {
12
- path: '/test',
13
- name: 'test-project',
14
- frameworks: ['NestJS'],
15
- totalFiles: 50,
16
- totalLines: 5000,
17
- primaryLanguages: ['TypeScript'],
18
- },
19
- score: {
20
- overall: 72,
21
- components: [],
22
- breakdown: { modularity: 80, coupling: 65, cohesion: 70, layering: 75 },
23
- },
24
- antiPatterns: [
25
- {
26
- name: 'God Class',
27
- severity: 'CRITICAL',
28
- location: 'src/AppService.ts',
29
- description: 'Class with 800 lines',
30
- suggestion: 'Split into smaller services',
31
- affectedFiles: ['src/AppService.ts'],
32
- },
33
- ],
34
- layers: [
35
- { name: 'API', files: ['src/controller.ts'], description: 'API layer' },
36
- { name: 'Service', files: ['src/service.ts'], description: 'Service layer' },
37
- ],
38
- dependencyGraph: {
39
- nodes: ['src/app.module.ts', 'src/app.controller.ts', 'src/app.service.ts', 'src/entity/user.entity.ts'],
40
- edges: [
41
- { from: 'src/app.controller.ts', to: 'src/app.service.ts', type: 'import', weight: 1 },
42
- { from: 'src/app.service.ts', to: 'src/entity/user.entity.ts', type: 'import', weight: 1 },
43
- ],
44
- },
45
- suggestions: [],
46
- diagram: { mermaid: '', type: 'layer' },
47
- ...overrides,
48
- };
49
- }
50
-
51
- function makePlan(overrides: Partial<RefactoringPlan> = {}): RefactoringPlan {
52
- return {
53
- timestamp: new Date().toISOString(),
54
- projectPath: '/test',
55
- currentScore: {
56
- overall: 72,
57
- components: [],
58
- breakdown: { modularity: 80, coupling: 65, cohesion: 70, layering: 75 },
59
- },
60
- estimatedScoreAfter: { overall: 82, breakdown: { modularity: 85, coupling: 75, cohesion: 80, layering: 80 } },
61
- steps: [
62
- {
63
- id: 1,
64
- tier: 1,
65
- rule: 'hub-splitter',
66
- priority: 'HIGH',
67
- title: 'Split AppService',
68
- description: 'Split monolith service',
69
- rationale: 'Reduce coupling',
70
- operations: [],
71
- scoreImpact: [{ metric: 'modularity', before: 80, after: 85 }],
72
- },
73
- ],
74
- totalOperations: 1,
75
- tier1Steps: 1,
76
- tier2Steps: 0,
77
- ...overrides,
78
- };
79
- }
80
-
81
- // ── Test Suite ──
82
-
83
- describe('AgentGenerator', () => {
84
- const generator = new AgentGenerator();
85
- const testOutputDir = join(process.cwd(), '__test_agent_output__');
86
-
87
- afterEach(() => {
88
- // Clean up generated test directories
89
- if (existsSync(testOutputDir)) {
90
- rmSync(testOutputDir, { recursive: true, force: true });
91
- }
92
- });
93
-
94
- describe('suggest()', () => {
95
- it('should return a valid AgentSuggestion', () => {
96
- const report = makeReport();
97
- const plan = makePlan();
98
-
99
- const result = generator.suggest(report, plan, '/test');
100
-
101
- expect(result).toBeDefined();
102
- expect(result.stack).toBeDefined();
103
- expect(result.suggestedAgents).toBeDefined();
104
- expect(result.suggestedRules).toBeDefined();
105
- expect(result.suggestedGuards).toBeDefined();
106
- expect(result.suggestedWorkflows).toBeDefined();
107
- expect(result.suggestedSkills).toBeDefined();
108
- expect(result.command).toBeDefined();
109
- });
110
-
111
- it('should detect TypeScript + NestJS stack', () => {
112
- const report = makeReport();
113
- const plan = makePlan();
114
-
115
- const result = generator.suggest(report, plan, '/test');
116
-
117
- expect(result.stack.primary).toBe('TypeScript');
118
- expect(result.stack.frameworks).toContain('NestJS');
119
- expect(result.stack.hasBackend).toBe(true);
120
- expect(result.stack.hasDatabase).toBe(true);
121
- });
122
-
123
- it('should suggest backend agent for backend stack', () => {
124
- const report = makeReport();
125
- const plan = makePlan();
126
-
127
- const result = generator.suggest(report, plan, '/test');
128
-
129
- const backendAgent = result.suggestedAgents.find(a => a.name.includes('BACKEND'));
130
- expect(backendAgent).toBeDefined();
131
- expect(backendAgent!.status).toBe('CREATE');
132
- });
133
-
134
- it('should suggest database agent when database detected', () => {
135
- const report = makeReport();
136
- const plan = makePlan();
137
-
138
- const result = generator.suggest(report, plan, '/test');
139
-
140
- const dbAgent = result.suggestedAgents.find(a => a.name.includes('DATABASE'));
141
- expect(dbAgent).toBeDefined();
142
- });
143
-
144
- it('should always suggest orchestrator, security, QA, and tech debt agents', () => {
145
- const report = makeReport();
146
- const plan = makePlan();
147
-
148
- const result = generator.suggest(report, plan, '/test');
149
- const names = result.suggestedAgents.map(a => a.name);
150
-
151
- expect(names).toContain('AGENT-ORCHESTRATOR');
152
- expect(names.some(n => n.includes('SECURITY'))).toBe(true);
153
- expect(names.some(n => n.includes('QA'))).toBe(true);
154
- expect(names.some(n => n.includes('TECH-DEBT'))).toBe(true);
155
- });
156
-
157
- it('should suggest 3+ rules including architecture and security', () => {
158
- const report = makeReport();
159
- const plan = makePlan();
160
-
161
- const result = generator.suggest(report, plan, '/test');
162
- const ruleNames = result.suggestedRules.map(r => r.name);
163
-
164
- expect(ruleNames).toContain('00-general');
165
- expect(ruleNames).toContain('01-architecture');
166
- expect(ruleNames).toContain('02-security');
167
- });
168
-
169
- it('should suggest stack-specific rule for NestJS', () => {
170
- const report = makeReport();
171
- const plan = makePlan();
172
-
173
- const result = generator.suggest(report, plan, '/test');
174
- const ruleNames = result.suggestedRules.map(r => r.name);
175
-
176
- expect(ruleNames.some(n => n.includes('03-nestjs'))).toBe(true);
177
- });
178
-
179
- it('should suggest 3 guards', () => {
180
- const report = makeReport();
181
- const plan = makePlan();
182
-
183
- const result = generator.suggest(report, plan, '/test');
184
-
185
- expect(result.suggestedGuards.length).toBe(3);
186
- const names = result.suggestedGuards.map(g => g.name);
187
- expect(names).toContain('PREFLIGHT');
188
- expect(names).toContain('QUALITY-GATES');
189
- expect(names).toContain('CODE-REVIEW-CHECKLIST');
190
- });
191
-
192
- it('should suggest 3 workflows', () => {
193
- const report = makeReport();
194
- const plan = makePlan();
195
-
196
- const result = generator.suggest(report, plan, '/test');
197
-
198
- expect(result.suggestedWorkflows.length).toBe(3);
199
- const names = result.suggestedWorkflows.map(w => w.name);
200
- expect(names).toContain('new-feature');
201
- expect(names).toContain('fix-bug');
202
- expect(names).toContain('review');
203
- });
204
-
205
- it('should suggest skills including stack-specific ones', () => {
206
- const report = makeReport();
207
- const plan = makePlan();
208
-
209
- const result = generator.suggest(report, plan, '/test');
210
-
211
- expect(result.suggestedSkills.length).toBeGreaterThan(5);
212
- const skillNames = result.suggestedSkills.map(s => s.name);
213
- expect(skillNames).toContain('test-driven-development');
214
- expect(skillNames).toContain('security-best-practices');
215
- // TypeScript-specific
216
- expect(skillNames).toContain('api-design-principles');
217
- });
218
-
219
- it('should mark hasExistingAgents false for non-existing directory', () => {
220
- const report = makeReport();
221
- const plan = makePlan();
222
-
223
- const result = generator.suggest(report, plan, '/non-existing-path');
224
-
225
- expect(result.hasExistingAgents).toBe(false);
226
- });
227
- });
228
-
229
- describe('generate() — full generation', () => {
230
- it('should create .agent/ directory structure', () => {
231
- const report = makeReport();
232
- const plan = makePlan();
233
-
234
- const result = generator.generate(report, plan, '/test', testOutputDir);
235
-
236
- expect(result.generated.length).toBeGreaterThan(15);
237
- expect(result.audit).toHaveLength(0); // No audit for fresh generation
238
-
239
- // Verify directory structure
240
- expect(existsSync(join(testOutputDir, 'agents'))).toBe(true);
241
- expect(existsSync(join(testOutputDir, 'rules'))).toBe(true);
242
- expect(existsSync(join(testOutputDir, 'guards'))).toBe(true);
243
- expect(existsSync(join(testOutputDir, 'workflows'))).toBe(true);
244
- expect(existsSync(join(testOutputDir, 'templates'))).toBe(true);
245
- expect(existsSync(join(testOutputDir, 'skills'))).toBe(true);
246
- });
247
-
248
- it('should generate core files', () => {
249
- const report = makeReport();
250
- const plan = makePlan();
251
-
252
- const result = generator.generate(report, plan, '/test', testOutputDir);
253
-
254
- expect(result.generated).toContain('INDEX.md');
255
- expect(result.generated).toContain('agents/AGENT-ORCHESTRATOR.md');
256
- expect(result.generated).toContain('guards/PREFLIGHT.md');
257
- expect(result.generated).toContain('guards/QUALITY-GATES.md');
258
- expect(result.generated).toContain('rules/00-general.md');
259
- expect(result.generated).toContain('rules/01-architecture.md');
260
- expect(result.generated).toContain('rules/02-security.md');
261
- expect(result.generated).toContain('workflows/new-feature.md');
262
- expect(result.generated).toContain('workflows/fix-bug.md');
263
- expect(result.generated).toContain('workflows/review.md');
264
- });
265
-
266
- it('should generate stack-specific agents for NestJS', () => {
267
- const report = makeReport();
268
- const plan = makePlan();
269
-
270
- const result = generator.generate(report, plan, '/test', testOutputDir);
271
-
272
- expect(result.generated.some(f => f.includes('TYPESCRIPT-BACKEND-DEVELOPER'))).toBe(true);
273
- expect(result.generated.some(f => f.includes('DATABASE-ENGINEER'))).toBe(true);
274
- });
275
-
276
- it('should generate stack-specific rules for NestJS', () => {
277
- const report = makeReport();
278
- const plan = makePlan();
279
-
280
- const result = generator.generate(report, plan, '/test', testOutputDir);
281
-
282
- expect(result.generated.some(f => f.includes('03-nestjs'))).toBe(true);
283
- });
284
-
285
- it('should generate domain templates', () => {
286
- const report = makeReport();
287
- const plan = makePlan();
288
-
289
- const result = generator.generate(report, plan, '/test', testOutputDir);
290
-
291
- expect(result.generated).toContain('templates/C4.md');
292
- expect(result.generated).toContain('templates/BDD.md');
293
- expect(result.generated).toContain('templates/TDD.md');
294
- expect(result.generated).toContain('templates/ADR.md');
295
- expect(result.generated).toContain('templates/THREAT-MODEL.md');
296
- });
297
-
298
- it('should generate frontend agent when frontend detected', () => {
299
- const report = makeReport({
300
- projectInfo: {
301
- path: '/test',
302
- name: 'test-project',
303
- frameworks: ['Angular'],
304
- totalFiles: 50,
305
- totalLines: 5000,
306
- primaryLanguages: ['TypeScript'],
307
- },
308
- dependencyGraph: {
309
- nodes: ['src/app.component.ts', 'src/app.module.ts', 'src/angular.json'],
310
- edges: [],
311
- },
312
- });
313
- const plan = makePlan();
314
-
315
- const result = generator.generate(report, plan, '/test', testOutputDir);
316
-
317
- expect(result.generated.some(f => f.includes('FRONTEND-DEVELOPER'))).toBe(true);
318
- });
319
-
320
- it('should generate mobile agent when Dart detected', () => {
321
- const report = makeReport({
322
- dependencyGraph: {
323
- nodes: ['lib/main.dart', 'lib/app.dart'],
324
- edges: [],
325
- },
326
- });
327
- const plan = makePlan();
328
-
329
- const result = generator.generate(report, plan, '/test', testOutputDir);
330
-
331
- expect(result.generated.some(f => f.includes('FLUTTER-UI-DEVELOPER'))).toBe(true);
332
- });
333
-
334
- it('should generate 18+ files total for a full NestJS project', () => {
335
- const report = makeReport();
336
- const plan = makePlan();
337
-
338
- const result = generator.generate(report, plan, '/test', testOutputDir);
339
-
340
- // Core: INDEX + ORCHESTRATOR + PREFLIGHT + QUALITY-GATES + CODE-REVIEW +
341
- // 00-general + 01-architecture + 02-security + 03-nestjs +
342
- // new-feature + fix-bug + review = 12
343
- // Agents: BACKEND + DATABASE + SECURITY + QA + TECH-DEBT = 5
344
- // Templates: C4 + BDD + TDD + ADR + THREAT-MODEL = 5
345
- // Total: 22+
346
- expect(result.generated.length).toBeGreaterThanOrEqual(18);
347
- });
348
- });
349
-
350
- describe('generate() — audit existing', () => {
351
- it('should audit and generate missing files', () => {
352
- // Create a partial .agent/ directory
353
- mkdirSync(join(testOutputDir, 'agents'), { recursive: true });
354
- mkdirSync(join(testOutputDir, 'rules'), { recursive: true });
355
- writeFileSync(join(testOutputDir, 'INDEX.md'), '# Existing Index');
356
- writeFileSync(join(testOutputDir, 'agents/AGENT-ORCHESTRATOR.md'), '# Existing Orchestrator');
357
-
358
- const report = makeReport();
359
- const plan = makePlan();
360
-
361
- const result = generator.generate(report, plan, '/test', testOutputDir);
362
-
363
- // Should have audit findings
364
- expect(result.audit.length).toBeGreaterThan(0);
365
-
366
- // Should have found some files OK
367
- const okFindings = result.audit.filter(f => f.type === 'OK');
368
- expect(okFindings.length).toBeGreaterThanOrEqual(2); // INDEX.md + ORCHESTRATOR
369
-
370
- // Should have found some missing
371
- const missingFindings = result.audit.filter(f => f.type === 'MISSING');
372
- expect(missingFindings.length).toBeGreaterThan(0);
373
-
374
- // Should have generated the missing files
375
- expect(result.generated.length).toBeGreaterThan(0);
376
- });
377
-
378
- it('should suggest improvement when score is low', () => {
379
- mkdirSync(join(testOutputDir, 'agents'), { recursive: true });
380
- mkdirSync(join(testOutputDir, 'guards'), { recursive: true });
381
- writeFileSync(join(testOutputDir, 'INDEX.md'), '# Index');
382
- writeFileSync(join(testOutputDir, 'guards/QUALITY-GATES.md'), '# Gates');
383
-
384
- const report = makeReport({
385
- score: {
386
- overall: 50,
387
- components: [],
388
- breakdown: { modularity: 50, coupling: 45, cohesion: 55, layering: 50 },
389
- },
390
- });
391
- const plan = makePlan();
392
-
393
- const result = generator.generate(report, plan, '/test', testOutputDir);
394
-
395
- const improvements = result.audit.filter(f => f.type === 'IMPROVEMENT');
396
- expect(improvements.length).toBeGreaterThan(0);
397
- });
398
- });
399
-
400
- describe('Python stack generation', () => {
401
- it('should generate Python-specific agents and rules', () => {
402
- const report = makeReport({
403
- projectInfo: {
404
- path: '/test',
405
- name: 'test-project',
406
- frameworks: ['Django'],
407
- totalFiles: 50,
408
- totalLines: 5000,
409
- primaryLanguages: ['Python'],
410
- },
411
- dependencyGraph: {
412
- nodes: ['manage.py', 'app/views.py', 'app/models.py', 'app/serializers.py'],
413
- edges: [
414
- { from: 'app/views.py', to: 'app/models.py', type: 'import', weight: 1 },
415
- ],
416
- },
417
- });
418
- const plan = makePlan();
419
-
420
- const result = generator.generate(report, plan, '/test', testOutputDir);
421
-
422
- // Should detect Python + Django
423
- expect(result.generated.some(f => f.includes('PYTHON-BACKEND-DEVELOPER'))).toBe(true);
424
- expect(result.generated.some(f => f.includes('03-django'))).toBe(true);
425
- });
426
- });
427
- });