@girardelli/architect 2.2.0 → 5.0.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 (212) hide show
  1. package/README.md +105 -116
  2. package/architect-run.sh +431 -0
  3. package/assets/banner-v3.html +561 -0
  4. package/dist/agent-generator/context-enricher.d.ts +58 -0
  5. package/dist/agent-generator/context-enricher.d.ts.map +1 -0
  6. package/dist/agent-generator/context-enricher.js +613 -0
  7. package/dist/agent-generator/context-enricher.js.map +1 -0
  8. package/dist/agent-generator/domain-inferrer.d.ts +52 -0
  9. package/dist/agent-generator/domain-inferrer.d.ts.map +1 -0
  10. package/dist/agent-generator/domain-inferrer.js +585 -0
  11. package/dist/agent-generator/domain-inferrer.js.map +1 -0
  12. package/dist/agent-generator/framework-detector.d.ts +40 -0
  13. package/dist/agent-generator/framework-detector.d.ts.map +1 -0
  14. package/dist/agent-generator/framework-detector.js +611 -0
  15. package/dist/agent-generator/framework-detector.js.map +1 -0
  16. package/dist/agent-generator/index.d.ts +47 -0
  17. package/dist/agent-generator/index.d.ts.map +1 -0
  18. package/dist/agent-generator/index.js +545 -0
  19. package/dist/agent-generator/index.js.map +1 -0
  20. package/dist/agent-generator/stack-detector.d.ts +14 -0
  21. package/dist/agent-generator/stack-detector.d.ts.map +1 -0
  22. package/dist/agent-generator/stack-detector.js +124 -0
  23. package/dist/agent-generator/stack-detector.js.map +1 -0
  24. package/dist/agent-generator/templates/core/agents.d.ts +17 -0
  25. package/dist/agent-generator/templates/core/agents.d.ts.map +1 -0
  26. package/dist/agent-generator/templates/core/agents.js +1256 -0
  27. package/dist/agent-generator/templates/core/agents.js.map +1 -0
  28. package/dist/agent-generator/templates/core/architecture-rules.d.ts +7 -0
  29. package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +1 -0
  30. package/dist/agent-generator/templates/core/architecture-rules.js +274 -0
  31. package/dist/agent-generator/templates/core/architecture-rules.js.map +1 -0
  32. package/dist/agent-generator/templates/core/general-rules.d.ts +8 -0
  33. package/dist/agent-generator/templates/core/general-rules.d.ts.map +1 -0
  34. package/dist/agent-generator/templates/core/general-rules.js +301 -0
  35. package/dist/agent-generator/templates/core/general-rules.js.map +1 -0
  36. package/dist/agent-generator/templates/core/hooks-generator.d.ts +21 -0
  37. package/dist/agent-generator/templates/core/hooks-generator.d.ts.map +1 -0
  38. package/dist/agent-generator/templates/core/hooks-generator.js +233 -0
  39. package/dist/agent-generator/templates/core/hooks-generator.js.map +1 -0
  40. package/dist/agent-generator/templates/core/index-md.d.ts +7 -0
  41. package/dist/agent-generator/templates/core/index-md.d.ts.map +1 -0
  42. package/dist/agent-generator/templates/core/index-md.js +246 -0
  43. package/dist/agent-generator/templates/core/index-md.js.map +1 -0
  44. package/dist/agent-generator/templates/core/orchestrator.d.ts +8 -0
  45. package/dist/agent-generator/templates/core/orchestrator.d.ts.map +1 -0
  46. package/dist/agent-generator/templates/core/orchestrator.js +422 -0
  47. package/dist/agent-generator/templates/core/orchestrator.js.map +1 -0
  48. package/dist/agent-generator/templates/core/preflight.d.ts +8 -0
  49. package/dist/agent-generator/templates/core/preflight.d.ts.map +1 -0
  50. package/dist/agent-generator/templates/core/preflight.js +213 -0
  51. package/dist/agent-generator/templates/core/preflight.js.map +1 -0
  52. package/dist/agent-generator/templates/core/quality-gates.d.ts +11 -0
  53. package/dist/agent-generator/templates/core/quality-gates.d.ts.map +1 -0
  54. package/dist/agent-generator/templates/core/quality-gates.js +254 -0
  55. package/dist/agent-generator/templates/core/quality-gates.js.map +1 -0
  56. package/dist/agent-generator/templates/core/security-rules.d.ts +7 -0
  57. package/dist/agent-generator/templates/core/security-rules.d.ts.map +1 -0
  58. package/dist/agent-generator/templates/core/security-rules.js +528 -0
  59. package/dist/agent-generator/templates/core/security-rules.js.map +1 -0
  60. package/dist/agent-generator/templates/core/skills-generator.d.ts +19 -0
  61. package/dist/agent-generator/templates/core/skills-generator.d.ts.map +1 -0
  62. package/dist/agent-generator/templates/core/skills-generator.js +546 -0
  63. package/dist/agent-generator/templates/core/skills-generator.js.map +1 -0
  64. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +7 -0
  65. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +1 -0
  66. package/dist/agent-generator/templates/core/workflow-fix-bug.js +237 -0
  67. package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
  68. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +8 -0
  69. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +1 -0
  70. package/dist/agent-generator/templates/core/workflow-new-feature.js +321 -0
  71. package/dist/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
  72. package/dist/agent-generator/templates/core/workflow-review.d.ts +7 -0
  73. package/dist/agent-generator/templates/core/workflow-review.d.ts.map +1 -0
  74. package/dist/agent-generator/templates/core/workflow-review.js +104 -0
  75. package/dist/agent-generator/templates/core/workflow-review.js.map +1 -0
  76. package/dist/agent-generator/templates/domain/index.d.ts +22 -0
  77. package/dist/agent-generator/templates/domain/index.d.ts.map +1 -0
  78. package/dist/agent-generator/templates/domain/index.js +1176 -0
  79. package/dist/agent-generator/templates/domain/index.js.map +1 -0
  80. package/dist/agent-generator/templates/stack/index.d.ts +8 -0
  81. package/dist/agent-generator/templates/stack/index.d.ts.map +1 -0
  82. package/dist/agent-generator/templates/stack/index.js +695 -0
  83. package/dist/agent-generator/templates/stack/index.js.map +1 -0
  84. package/dist/agent-generator/templates/template-helpers.d.ts +75 -0
  85. package/dist/agent-generator/templates/template-helpers.d.ts.map +1 -0
  86. package/dist/agent-generator/templates/template-helpers.js +726 -0
  87. package/dist/agent-generator/templates/template-helpers.js.map +1 -0
  88. package/dist/agent-generator/types.d.ts +196 -0
  89. package/dist/agent-generator/types.d.ts.map +1 -0
  90. package/dist/agent-generator/types.js +27 -0
  91. package/dist/agent-generator/types.js.map +1 -0
  92. package/dist/analyzer.d.ts +5 -0
  93. package/dist/analyzer.d.ts.map +1 -1
  94. package/dist/analyzer.js +46 -5
  95. package/dist/analyzer.js.map +1 -1
  96. package/dist/analyzers/forecast.d.ts +85 -0
  97. package/dist/analyzers/forecast.d.ts.map +1 -0
  98. package/dist/analyzers/forecast.js +337 -0
  99. package/dist/analyzers/forecast.js.map +1 -0
  100. package/dist/analyzers/git-cache.d.ts +7 -0
  101. package/dist/analyzers/git-cache.d.ts.map +1 -0
  102. package/dist/analyzers/git-cache.js +41 -0
  103. package/dist/analyzers/git-cache.js.map +1 -0
  104. package/dist/analyzers/git-history.d.ts +113 -0
  105. package/dist/analyzers/git-history.d.ts.map +1 -0
  106. package/dist/analyzers/git-history.js +333 -0
  107. package/dist/analyzers/git-history.js.map +1 -0
  108. package/dist/analyzers/index.d.ts +10 -0
  109. package/dist/analyzers/index.d.ts.map +1 -0
  110. package/dist/analyzers/index.js +7 -0
  111. package/dist/analyzers/index.js.map +1 -0
  112. package/dist/analyzers/temporal-scorer.d.ts +72 -0
  113. package/dist/analyzers/temporal-scorer.d.ts.map +1 -0
  114. package/dist/analyzers/temporal-scorer.js +140 -0
  115. package/dist/analyzers/temporal-scorer.js.map +1 -0
  116. package/dist/anti-patterns.d.ts +7 -0
  117. package/dist/anti-patterns.d.ts.map +1 -1
  118. package/dist/anti-patterns.js +25 -6
  119. package/dist/anti-patterns.js.map +1 -1
  120. package/dist/cli.d.ts +2 -3
  121. package/dist/cli.d.ts.map +1 -1
  122. package/dist/cli.js +275 -113
  123. package/dist/cli.js.map +1 -1
  124. package/dist/config.d.ts +6 -0
  125. package/dist/config.d.ts.map +1 -1
  126. package/dist/config.js +48 -11
  127. package/dist/config.js.map +1 -1
  128. package/dist/html-reporter.d.ts +3 -1
  129. package/dist/html-reporter.d.ts.map +1 -1
  130. package/dist/html-reporter.js +248 -12
  131. package/dist/html-reporter.js.map +1 -1
  132. package/dist/index.d.ts +16 -3
  133. package/dist/index.d.ts.map +1 -1
  134. package/dist/index.js +63 -4
  135. package/dist/index.js.map +1 -1
  136. package/dist/project-summarizer.d.ts +38 -0
  137. package/dist/project-summarizer.d.ts.map +1 -0
  138. package/dist/project-summarizer.js +463 -0
  139. package/dist/project-summarizer.js.map +1 -0
  140. package/dist/refactor-reporter.js +1 -1
  141. package/dist/scanner.d.ts +8 -2
  142. package/dist/scanner.d.ts.map +1 -1
  143. package/dist/scanner.js +153 -113
  144. package/dist/scanner.js.map +1 -1
  145. package/dist/scorer.d.ts.map +1 -1
  146. package/dist/scorer.js +24 -11
  147. package/dist/scorer.js.map +1 -1
  148. package/dist/types.d.ts +29 -0
  149. package/dist/types.d.ts.map +1 -1
  150. package/package.json +12 -3
  151. package/src/agent-generator/context-enricher.ts +672 -0
  152. package/src/agent-generator/domain-inferrer.ts +635 -0
  153. package/src/agent-generator/framework-detector.ts +669 -0
  154. package/src/agent-generator/index.ts +634 -0
  155. package/src/agent-generator/stack-detector.ts +115 -0
  156. package/src/agent-generator/templates/core/agents.ts +1296 -0
  157. package/src/agent-generator/templates/core/architecture-rules.ts +287 -0
  158. package/src/agent-generator/templates/core/general-rules.ts +306 -0
  159. package/src/agent-generator/templates/core/hooks-generator.ts +242 -0
  160. package/src/agent-generator/templates/core/index-md.ts +260 -0
  161. package/src/agent-generator/templates/core/orchestrator.ts +459 -0
  162. package/src/agent-generator/templates/core/preflight.ts +215 -0
  163. package/src/agent-generator/templates/core/quality-gates.ts +256 -0
  164. package/src/agent-generator/templates/core/security-rules.ts +543 -0
  165. package/src/agent-generator/templates/core/skills-generator.ts +585 -0
  166. package/src/agent-generator/templates/core/workflow-fix-bug.ts +239 -0
  167. package/src/agent-generator/templates/core/workflow-new-feature.ts +323 -0
  168. package/src/agent-generator/templates/core/workflow-review.ts +106 -0
  169. package/src/agent-generator/templates/domain/index.ts +1201 -0
  170. package/src/agent-generator/templates/stack/index.ts +705 -0
  171. package/src/agent-generator/templates/template-helpers.ts +776 -0
  172. package/src/agent-generator/types.ts +232 -0
  173. package/src/analyzer.ts +51 -5
  174. package/src/analyzers/forecast.ts +496 -0
  175. package/src/analyzers/git-cache.ts +52 -0
  176. package/src/analyzers/git-history.ts +488 -0
  177. package/src/analyzers/index.ts +33 -0
  178. package/src/analyzers/temporal-scorer.ts +227 -0
  179. package/src/anti-patterns.ts +29 -6
  180. package/src/cli.ts +316 -117
  181. package/src/config.ts +52 -11
  182. package/src/html-reporter.ts +263 -13
  183. package/src/index.ts +93 -10
  184. package/src/project-summarizer.ts +521 -0
  185. package/src/refactor-reporter.ts +1 -1
  186. package/src/scanner.ts +136 -90
  187. package/src/scorer.ts +26 -11
  188. package/src/types.ts +27 -0
  189. package/tests/agent-generator.test.ts +427 -0
  190. package/tests/analyzers-integration.test.ts +174 -0
  191. package/tests/architect-adapter-enrichment.test.ts +9 -0
  192. package/tests/context-enricher.test.ts +971 -0
  193. package/tests/fixtures/monorepo/package.json +6 -0
  194. package/tests/fixtures/monorepo/packages/app/package.json +12 -0
  195. package/tests/fixtures/monorepo/packages/app/src/index.ts +6 -0
  196. package/tests/fixtures/monorepo/packages/core/package.json +7 -0
  197. package/tests/fixtures/monorepo/packages/core/src/index.ts +7 -0
  198. package/tests/forecast.test.ts +509 -0
  199. package/tests/framework-detector.test.ts +1172 -0
  200. package/tests/git-history.test.ts +254 -0
  201. package/tests/monorepo-scan.test.ts +170 -0
  202. package/tests/scanner.test.ts +7 -8
  203. package/tests/scorer.test.ts +594 -0
  204. package/tests/stack-detector.test.ts +241 -0
  205. package/tests/template-generation.test.ts +706 -0
  206. package/tests/template-helpers.test.ts +1152 -0
  207. package/tests/temporal-scorer.test.ts +307 -0
  208. package/dist/agent-generator.d.ts +0 -106
  209. package/dist/agent-generator.d.ts.map +0 -1
  210. package/dist/agent-generator.js +0 -1398
  211. package/dist/agent-generator.js.map +0 -1
  212. package/src/agent-generator.ts +0 -1526
@@ -0,0 +1,232 @@
1
+ import { AnalysisReport, RefactoringPlan } from '../types.js';
2
+
3
+ /**
4
+ * Stack detection result from project analysis.
5
+ */
6
+ export interface StackInfo {
7
+ primary: string;
8
+ languages: string[];
9
+ frameworks: string[];
10
+ hasBackend: boolean;
11
+ hasFrontend: boolean;
12
+ hasMobile: boolean;
13
+ hasDatabase: boolean;
14
+ testFramework: string;
15
+ packageManager: string;
16
+ }
17
+
18
+ /**
19
+ * Audit finding for existing agent directories.
20
+ */
21
+ export interface AgentAuditFinding {
22
+ type: 'MISSING' | 'OUTDATED' | 'IMPROVEMENT' | 'OK';
23
+ category: string;
24
+ file: string;
25
+ description: string;
26
+ suggestion?: string;
27
+ }
28
+
29
+ /**
30
+ * Status of each agent system item relative to existing .agent/ directory.
31
+ */
32
+ export type AgentItemStatus = 'KEEP' | 'MODIFY' | 'CREATE' | 'DELETE';
33
+
34
+ export interface AgentItem {
35
+ name: string;
36
+ status: AgentItemStatus;
37
+ reason?: string;
38
+ description?: string;
39
+ }
40
+
41
+ /**
42
+ * Result from suggest() — no files written, just recommendations.
43
+ */
44
+ export interface AgentSuggestion {
45
+ stack: StackInfo;
46
+ hasExistingAgents: boolean;
47
+ suggestedAgents: AgentItem[];
48
+ suggestedRules: AgentItem[];
49
+ suggestedGuards: AgentItem[];
50
+ suggestedWorkflows: AgentItem[];
51
+ suggestedSkills: { name: string; source: string; description: string; status: AgentItemStatus }[];
52
+ audit: AgentAuditFinding[];
53
+ command: string;
54
+ }
55
+
56
+ /**
57
+ * Context passed to all template generators.
58
+ */
59
+ export interface TemplateContext {
60
+ report: AnalysisReport;
61
+ plan: RefactoringPlan;
62
+ stack: StackInfo;
63
+ projectName: string;
64
+ stackLabel: string;
65
+ config: AgentGeneratorConfig;
66
+ }
67
+
68
+ /**
69
+ * Configuration for agent generation — customizable per project.
70
+ */
71
+ export interface AgentGeneratorConfig {
72
+ coverageMinimum: number;
73
+ scoreThreshold: number;
74
+ language: 'pt-BR' | 'en';
75
+ goldenRules: string[];
76
+ blockers: string[];
77
+ }
78
+
79
+ /**
80
+ * Domain classification inferred from project analysis.
81
+ */
82
+ export interface DomainInsights {
83
+ /** Primary domain category (e.g., 'fintech', 'healthtech', 'e-commerce') */
84
+ domain: string;
85
+ /** Specific sub-domain (e.g., 'tax-processing', 'payment-gateway') */
86
+ subDomain: string;
87
+ /** Human-readable description of what the project does */
88
+ description: string;
89
+ /** Business entities detected from models/entities/schemas */
90
+ businessEntities: BusinessEntity[];
91
+ /** Regulatory/compliance requirements inferred from domain */
92
+ compliance: ComplianceRequirement[];
93
+ /** External integrations detected or inferred */
94
+ integrations: ExternalIntegration[];
95
+ /** Domain-specific keywords extracted from code */
96
+ keywords: string[];
97
+ /** Confidence level of domain inference (0-1) */
98
+ confidence: number;
99
+ }
100
+
101
+ export interface BusinessEntity {
102
+ name: string;
103
+ source: string; // file path where detected
104
+ fields: string[];
105
+ relationships: string[];
106
+ layer: 'model' | 'entity' | 'schema' | 'dto' | 'unknown';
107
+ }
108
+
109
+ export interface ComplianceRequirement {
110
+ name: string; // e.g., 'LGPD', 'HIPAA', 'PCI-DSS', 'SOX', 'GDPR'
111
+ reason: string;
112
+ mandatoryChecks: string[];
113
+ }
114
+
115
+ export interface ExternalIntegration {
116
+ name: string;
117
+ type: 'api' | 'database' | 'queue' | 'storage' | 'payment' | 'auth' | 'government' | 'other';
118
+ detectedFrom: string;
119
+ }
120
+
121
+ /**
122
+ * Detailed module information extracted from project analysis.
123
+ */
124
+ export interface ModuleDetail {
125
+ name: string;
126
+ path: string;
127
+ files: string[];
128
+ fileCount: number;
129
+ lineCount: number;
130
+ description: string;
131
+ hasTests: boolean;
132
+ testFiles: string[];
133
+ entities: string[];
134
+ controllers: string[];
135
+ services: string[];
136
+ layer: string;
137
+ }
138
+
139
+ /**
140
+ * API endpoint detected from route/controller files.
141
+ */
142
+ export interface DetectedEndpoint {
143
+ method: string; // GET, POST, PUT, DELETE, PATCH
144
+ path: string;
145
+ file: string;
146
+ handler: string;
147
+ hasAuth: boolean;
148
+ hasValidation: boolean;
149
+ }
150
+
151
+ /**
152
+ * Detected framework with version, detected from dependency files.
153
+ */
154
+ export interface FrameworkInfo {
155
+ /** Framework name (e.g., 'FastAPI', 'NestJS', 'Django', 'Spring Boot') */
156
+ name: string;
157
+ /** Detected version (e.g., '0.104.1') or null */
158
+ version: string | null;
159
+ /** Category of framework */
160
+ category: 'web' | 'orm' | 'test' | 'lint' | 'build' | 'other';
161
+ /** Confidence level (0-1) */
162
+ confidence: number;
163
+ }
164
+
165
+ /**
166
+ * Detected toolchain — build, test, lint, run commands.
167
+ */
168
+ export interface DetectedToolchain {
169
+ /** Build command (e.g., 'npm run build', 'make build', 'mvn package') */
170
+ buildCmd: string;
171
+ /** Test command (e.g., 'pytest', 'npm test', 'go test ./...') */
172
+ testCmd: string;
173
+ /** Lint command (e.g., 'ruff check .', 'eslint .', 'golangci-lint run') */
174
+ lintCmd: string;
175
+ /** Run/dev command (e.g., 'uvicorn main:app', 'npm run dev') */
176
+ runCmd: string;
177
+ /** Coverage command */
178
+ coverageCmd: string;
179
+ /** Dependency install command */
180
+ installCmd: string;
181
+ /** Migration command (if applicable) */
182
+ migrateCmd: string | null;
183
+ /** Dependency file (e.g., 'requirements.txt', 'package.json') */
184
+ depsFile: string;
185
+ }
186
+
187
+ /**
188
+ * Enriched template context with domain awareness.
189
+ */
190
+ export interface EnrichedTemplateContext extends TemplateContext {
191
+ domain: DomainInsights;
192
+ modules: ModuleDetail[];
193
+ endpoints: DetectedEndpoint[];
194
+ untestedModules: string[];
195
+ criticalPaths: string[]; // files with highest coupling
196
+ projectDepth: 'small' | 'medium' | 'large' | 'enterprise'; // drives template verbosity
197
+ /** Detected frameworks with versions */
198
+ detectedFrameworks: FrameworkInfo[];
199
+ /** Primary web framework (e.g., 'FastAPI', 'NestJS', 'Django') */
200
+ primaryFramework: FrameworkInfo | null;
201
+ /** Detected toolchain commands */
202
+ toolchain: DetectedToolchain;
203
+ /** Real project structure pattern detected */
204
+ projectStructure: 'clean-architecture' | 'mvc' | 'modular' | 'flat' | 'monorepo' | 'unknown';
205
+ }
206
+
207
+ export const DEFAULT_AGENT_CONFIG: AgentGeneratorConfig = {
208
+ coverageMinimum: 80,
209
+ scoreThreshold: 70,
210
+ language: 'pt-BR',
211
+ goldenRules: [
212
+ 'Git Flow completo (branch → PR → review → merge)',
213
+ 'Arquitetura C4 (4 níveis de documentação)',
214
+ 'BDD antes de código',
215
+ 'TDD — Red → Green → Refactor',
216
+ 'Diagnóstico obrigatório antes de codar',
217
+ 'Mockup antes de qualquer UI',
218
+ 'Nunca decidir sozinho — perguntar ao humano',
219
+ 'Qualidade > Velocidade',
220
+ 'Não abrir browser, não tirar screenshot — apenas código',
221
+ ],
222
+ blockers: [
223
+ 'console.log / print() em código de produção',
224
+ 'TODO / FIXME / HACK sem issue vinculada',
225
+ 'any (TypeScript) / type: ignore (Python) sem justificativa',
226
+ 'Testes com .skip() ou @pytest.mark.skip sem motivo',
227
+ 'Secrets, tokens ou senhas hardcoded',
228
+ 'Push direto em main/develop',
229
+ 'Arquivos > 500 linhas sem justificativa',
230
+ 'Imports circulares',
231
+ ],
232
+ };
package/src/analyzer.ts CHANGED
@@ -1,5 +1,5 @@
1
- import { readFileSync } from 'fs';
2
- import { extname, relative, dirname } from 'path';
1
+ import { readFileSync, existsSync } from 'fs';
2
+ import { extname, relative, dirname, resolve, join } from 'path';
3
3
  import { DependencyEdge, Layer, FileNode } from './types.js';
4
4
 
5
5
  export class ArchitectureAnalyzer {
@@ -72,8 +72,9 @@ export class ArchitectureAnalyzer {
72
72
 
73
73
  private buildDependencyGraph(node: FileNode): void {
74
74
  if (node.type === 'file') {
75
- const imports = this.parseImports(node.path);
76
- this.dependencyGraph.set(node.path, new Set(imports));
75
+ const rawImports = this.parseImports(node.path);
76
+ const resolvedImports = rawImports.map(imp => this.resolveImportPath(node.path, imp));
77
+ this.dependencyGraph.set(node.path, new Set(resolvedImports));
77
78
  }
78
79
 
79
80
  if (node.children) {
@@ -83,6 +84,39 @@ export class ArchitectureAnalyzer {
83
84
  }
84
85
  }
85
86
 
87
+ /**
88
+ * Resolve a relative import path to an absolute file path.
89
+ * Tries common extensions (.ts, .tsx, .js, .jsx, /index.ts, etc.)
90
+ */
91
+ private resolveImportPath(fromFile: string, importPath: string): string {
92
+ // Non-relative imports (Python module names, etc.) — return as-is
93
+ if (!importPath.startsWith('.')) return importPath;
94
+
95
+ const dir = dirname(fromFile);
96
+ const base = resolve(dir, importPath);
97
+
98
+ // Common extensions to try
99
+ const extensions = ['.ts', '.tsx', '.js', '.jsx', '.py', '.dart', '.go', '.java', '.rb'];
100
+ const indexFiles = extensions.map(ext => join(base, `index${ext}`));
101
+
102
+ // Try exact match first
103
+ if (existsSync(base) && !existsSync(base + '/')) return base;
104
+
105
+ // Try with extensions
106
+ for (const ext of extensions) {
107
+ const candidate = base + ext;
108
+ if (existsSync(candidate)) return candidate;
109
+ }
110
+
111
+ // Try as directory with index file
112
+ for (const indexFile of indexFiles) {
113
+ if (existsSync(indexFile)) return indexFile;
114
+ }
115
+
116
+ // Fallback: return the resolved path even if file not found
117
+ return base;
118
+ }
119
+
86
120
  /**
87
121
  * Known Python standard library modules (partial list of most common ones)
88
122
  */
@@ -243,8 +277,20 @@ export class ArchitectureAnalyzer {
243
277
  const path = node.path.toLowerCase();
244
278
  const name = node.name.toLowerCase();
245
279
 
246
- // Data layercheck first (more specific patterns)
280
+ // Skip test files they don't belong to any architectural layer
247
281
  if (
282
+ name.endsWith('.test.ts') || name.endsWith('.test.js') ||
283
+ name.endsWith('.spec.ts') || name.endsWith('.spec.js') ||
284
+ path.includes('/__tests__/') || path.includes('/__mocks__/')
285
+ ) {
286
+ // Don't categorize test files into any layer
287
+ }
288
+ // Skip node_modules files (safety barrier)
289
+ else if (path.includes('node_modules')) {
290
+ // Don't categorize third-party files
291
+ }
292
+ // Data layer — check first (more specific patterns)
293
+ else if (
248
294
  path.includes('/entities/') ||
249
295
  path.includes('/entity/') ||
250
296
  path.includes('/migrations/') ||