@girardelli/architect 2.2.0 → 4.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.
- package/README.md +105 -116
- package/__test_agent_output__/INDEX.md +1 -0
- package/__test_agent_output__/agents/AGENT-ORCHESTRATOR.md +1 -0
- package/__test_agent_output__/agents/DATABASE-ENGINEER.md +174 -0
- package/__test_agent_output__/agents/QA-TEST-ENGINEER.md +138 -0
- package/__test_agent_output__/agents/SECURITY-AUDITOR.md +106 -0
- package/__test_agent_output__/agents/TECH-DEBT-CONTROLLER.md +104 -0
- package/__test_agent_output__/agents/TYPESCRIPT-BACKEND-DEVELOPER.md +135 -0
- package/__test_agent_output__/guards/CODE-REVIEW-CHECKLIST.md +95 -0
- package/__test_agent_output__/guards/PREFLIGHT.md +200 -0
- package/__test_agent_output__/guards/QUALITY-GATES.md +1 -0
- package/__test_agent_output__/rules/00-general.md +229 -0
- package/__test_agent_output__/rules/01-architecture.md +191 -0
- package/__test_agent_output__/rules/02-security.md +402 -0
- package/__test_agent_output__/rules/03-nestjs.md +124 -0
- package/__test_agent_output__/templates/ADR.md +95 -0
- package/__test_agent_output__/templates/BDD.md +58 -0
- package/__test_agent_output__/templates/C4.md +68 -0
- package/__test_agent_output__/templates/TDD.md +86 -0
- package/__test_agent_output__/templates/THREAT-MODEL.md +82 -0
- package/__test_agent_output__/workflows/fix-bug.md +228 -0
- package/__test_agent_output__/workflows/new-feature.md +311 -0
- package/__test_agent_output__/workflows/review.md +95 -0
- package/__test_context_7RvUrO/src/modules/empty/empty.ts +0 -0
- package/__test_context_Rf5fNJ/src/modules/mixed/mixed.ts +5 -0
- package/__test_context_WRCnYH/src/modules/test/test.ts +10 -0
- package/__test_context_YsnVS3/src/modules/test/test.ts +10 -0
- package/__test_context_w7XZeH/src/modules/mixed/mixed.ts +5 -0
- package/__test_context_y5noh6/src/modules/empty/empty.ts +0 -0
- package/__test_framework__24OjAu/package.json +1 -0
- package/__test_framework__3ZDZsx/pyproject.toml +8 -0
- package/__test_framework__4T54Jn/package.json +1 -0
- package/__test_framework__4tlXu9/pyproject.toml +8 -0
- package/__test_framework__6boWqQ/Pipfile +6 -0
- package/__test_framework__6gygMU/pom.xml +10 -0
- package/__test_framework__6kxj0N/go.mod +8 -0
- package/__test_framework__7CEoXw/pom.xml +10 -0
- package/__test_framework__85DDz0/Pipfile +6 -0
- package/__test_framework__9WrRIr/pom.xml +7 -0
- package/__test_framework__ANqGKl/Gemfile +5 -0
- package/__test_framework__BCXTEM/go.mod +3 -0
- package/__test_framework__BHiPNq/setup.py +2 -0
- package/__test_framework__BqkiKv/package.json +1 -0
- package/__test_framework__C5yd8X/Pipfile.lock +1 -0
- package/__test_framework__C5yd8X/requirements.txt +1 -0
- package/__test_framework__C87d3a/manage.py +1 -0
- package/__test_framework__C87d3a/requirements.txt +2 -0
- package/__test_framework__DXNwc5/build.gradle +7 -0
- package/__test_framework__GhHSt3/build.gradle.kts +4 -0
- package/__test_framework__GzklJP/Cargo.toml +7 -0
- package/__test_framework__H4hd13/go.mod +8 -0
- package/__test_framework__HKjOXO/composer.json +1 -0
- package/__test_framework__HaDN45/Gemfile +3 -0
- package/__test_framework__IBO7YG/pyproject.toml +9 -0
- package/__test_framework__JwSOyF/pyproject.toml +6 -0
- package/__test_framework__K6HrCr/build.gradle +2 -0
- package/__test_framework__KzRPlh/pubspec.yaml +9 -0
- package/__test_framework__L6uIym/pyproject.toml +6 -0
- package/__test_framework__LOdoGK/requirements.txt +4 -0
- package/__test_framework__LgHzss/package.json +1 -0
- package/__test_framework__M76M6q/Gemfile +5 -0
- package/__test_framework__Mr9vWW/composer.json +1 -0
- package/__test_framework__N03Gnv/package.json +1 -0
- package/__test_framework__Num4UE/requirements +1 -0
- package/__test_framework__OAGw3Y/build.gradle +7 -0
- package/__test_framework__OQc8yG/pubspec.yaml +9 -0
- package/__test_framework__OwKZcd/requirements.txt +3 -0
- package/__test_framework__P0gFv7/requirements +1 -0
- package/__test_framework__PN55Rq/package.json +1 -0
- package/__test_framework__PQiqX8/pubspec.yaml +3 -0
- package/__test_framework__RBHsg7/composer.json +1 -0
- package/__test_framework__RHxif4/Cargo.toml +7 -0
- package/__test_framework__T0v0p1/Cargo.toml +4 -0
- package/__test_framework__Tu0clt/Pipfile.lock +1 -0
- package/__test_framework__Tu0clt/requirements.txt +1 -0
- package/__test_framework__TwDj9P/Cargo.toml +4 -0
- package/__test_framework__VQJNC4/pom.xml +7 -0
- package/__test_framework__W6sm05/package.json +1 -0
- package/__test_framework__W7vBLy/pyproject.toml +4 -0
- package/__test_framework__WNJOWT/setup.py +2 -0
- package/__test_framework__WSJs7U/package.json +1 -0
- package/__test_framework__YQ5VpA/build.gradle.kts +4 -0
- package/__test_framework__ZNEUEs/package.json +1 -0
- package/__test_framework__Znt922/pom.xml +7 -0
- package/__test_framework__azyg0h/pom.xml +7 -0
- package/__test_framework__c6otLr/package.json +1 -0
- package/__test_framework__cl9S9G/build.gradle +2 -0
- package/__test_framework__eilvV4/composer.json +1 -0
- package/__test_framework__gQZxXO/manage.py +1 -0
- package/__test_framework__gQZxXO/requirements.txt +2 -0
- package/__test_framework__ghvl26/poetry.lock +1 -0
- package/__test_framework__ghvl26/pyproject.toml +2 -0
- package/__test_framework__hR7b9U/Makefile +11 -0
- package/__test_framework__iESVsi/composer.json +1 -0
- package/__test_framework__jm6TJy/package.json +1 -0
- package/__test_framework__kBUpjs/pyproject.toml +9 -0
- package/__test_framework__kqoZrw/requirements.txt +4 -0
- package/__test_framework__lWkoyO/pyproject.toml +4 -0
- package/__test_framework__mTKnUO/package.json +1 -0
- package/__test_framework__nCeZwe/Makefile +11 -0
- package/__test_framework__oljsU0/package.json +1 -0
- package/__test_framework__osRG4q/go.mod +3 -0
- package/__test_framework__pCHH4F/package.json +1 -0
- package/__test_framework__pExx6E/Gemfile +3 -0
- package/__test_framework__pyBoGd/pyproject.toml +5 -0
- package/__test_framework__qw16VQ/package.json +1 -0
- package/__test_framework__rRayrG/package.json +1 -0
- package/__test_framework__s82zO5/package.json +1 -0
- package/__test_framework__tp8MFK/pyproject.toml +5 -0
- package/__test_framework__w44k4w/composer.json +1 -0
- package/__test_framework__yefPZY/poetry.lock +1 -0
- package/__test_framework__yefPZY/pyproject.toml +2 -0
- package/__test_framework__zCiyDT/requirements.txt +3 -0
- package/__test_framework__zGZN3j/pubspec.yaml +3 -0
- package/__test_framework__zXpnxL/package.json +1 -0
- package/architect-run.sh +431 -0
- package/assets/banner-v3.html +561 -0
- package/dist/agent-generator/context-enricher.d.ts +58 -0
- package/dist/agent-generator/context-enricher.d.ts.map +1 -0
- package/dist/agent-generator/context-enricher.js +581 -0
- package/dist/agent-generator/context-enricher.js.map +1 -0
- package/dist/agent-generator/domain-inferrer.d.ts +52 -0
- package/dist/agent-generator/domain-inferrer.d.ts.map +1 -0
- package/dist/agent-generator/domain-inferrer.js +575 -0
- package/dist/agent-generator/domain-inferrer.js.map +1 -0
- package/dist/agent-generator/framework-detector.d.ts +40 -0
- package/dist/agent-generator/framework-detector.d.ts.map +1 -0
- package/dist/agent-generator/framework-detector.js +611 -0
- package/dist/agent-generator/framework-detector.js.map +1 -0
- package/dist/agent-generator/index.d.ts +33 -0
- package/dist/agent-generator/index.d.ts.map +1 -0
- package/dist/agent-generator/index.js +477 -0
- package/dist/agent-generator/index.js.map +1 -0
- package/dist/agent-generator/stack-detector.d.ts +12 -0
- package/dist/agent-generator/stack-detector.d.ts.map +1 -0
- package/dist/agent-generator/stack-detector.js +128 -0
- package/dist/agent-generator/stack-detector.js.map +1 -0
- package/dist/agent-generator/templates/core/agents.d.ts +17 -0
- package/dist/agent-generator/templates/core/agents.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/agents.js +1252 -0
- package/dist/agent-generator/templates/core/agents.js.map +1 -0
- package/dist/agent-generator/templates/core/architecture-rules.d.ts +7 -0
- package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/architecture-rules.js +274 -0
- package/dist/agent-generator/templates/core/architecture-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/general-rules.d.ts +8 -0
- package/dist/agent-generator/templates/core/general-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/general-rules.js +301 -0
- package/dist/agent-generator/templates/core/general-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/index-md.d.ts +7 -0
- package/dist/agent-generator/templates/core/index-md.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/index-md.js +246 -0
- package/dist/agent-generator/templates/core/index-md.js.map +1 -0
- package/dist/agent-generator/templates/core/orchestrator.d.ts +8 -0
- package/dist/agent-generator/templates/core/orchestrator.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/orchestrator.js +422 -0
- package/dist/agent-generator/templates/core/orchestrator.js.map +1 -0
- package/dist/agent-generator/templates/core/preflight.d.ts +8 -0
- package/dist/agent-generator/templates/core/preflight.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/preflight.js +213 -0
- package/dist/agent-generator/templates/core/preflight.js.map +1 -0
- package/dist/agent-generator/templates/core/quality-gates.d.ts +11 -0
- package/dist/agent-generator/templates/core/quality-gates.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/quality-gates.js +254 -0
- package/dist/agent-generator/templates/core/quality-gates.js.map +1 -0
- package/dist/agent-generator/templates/core/security-rules.d.ts +7 -0
- package/dist/agent-generator/templates/core/security-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/security-rules.js +528 -0
- package/dist/agent-generator/templates/core/security-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/skills-generator.d.ts +6 -0
- package/dist/agent-generator/templates/core/skills-generator.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/skills-generator.js +207 -0
- package/dist/agent-generator/templates/core/skills-generator.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +7 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.js +237 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +8 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.js +321 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-review.d.ts +7 -0
- package/dist/agent-generator/templates/core/workflow-review.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-review.js +104 -0
- package/dist/agent-generator/templates/core/workflow-review.js.map +1 -0
- package/dist/agent-generator/templates/domain/index.d.ts +22 -0
- package/dist/agent-generator/templates/domain/index.d.ts.map +1 -0
- package/dist/agent-generator/templates/domain/index.js +1176 -0
- package/dist/agent-generator/templates/domain/index.js.map +1 -0
- package/dist/agent-generator/templates/stack/index.d.ts +8 -0
- package/dist/agent-generator/templates/stack/index.d.ts.map +1 -0
- package/dist/agent-generator/templates/stack/index.js +695 -0
- package/dist/agent-generator/templates/stack/index.js.map +1 -0
- package/dist/agent-generator/templates/template-helpers.d.ts +75 -0
- package/dist/agent-generator/templates/template-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/template-helpers.js +726 -0
- package/dist/agent-generator/templates/template-helpers.js.map +1 -0
- package/dist/agent-generator/types.d.ts +196 -0
- package/dist/agent-generator/types.d.ts.map +1 -0
- package/dist/agent-generator/types.js +27 -0
- package/dist/agent-generator/types.js.map +1 -0
- package/dist/analyzer.d.ts +5 -0
- package/dist/analyzer.d.ts.map +1 -1
- package/dist/analyzer.js +35 -4
- package/dist/analyzer.js.map +1 -1
- package/dist/analyzers/forecast.d.ts +85 -0
- package/dist/analyzers/forecast.d.ts.map +1 -0
- package/dist/analyzers/forecast.js +337 -0
- package/dist/analyzers/forecast.js.map +1 -0
- package/dist/analyzers/git-cache.d.ts +7 -0
- package/dist/analyzers/git-cache.d.ts.map +1 -0
- package/dist/analyzers/git-cache.js +41 -0
- package/dist/analyzers/git-cache.js.map +1 -0
- package/dist/analyzers/git-history.d.ts +113 -0
- package/dist/analyzers/git-history.d.ts.map +1 -0
- package/dist/analyzers/git-history.js +333 -0
- package/dist/analyzers/git-history.js.map +1 -0
- package/dist/analyzers/index.d.ts +10 -0
- package/dist/analyzers/index.d.ts.map +1 -0
- package/dist/analyzers/index.js +7 -0
- package/dist/analyzers/index.js.map +1 -0
- package/dist/analyzers/temporal-scorer.d.ts +72 -0
- package/dist/analyzers/temporal-scorer.d.ts.map +1 -0
- package/dist/analyzers/temporal-scorer.js +140 -0
- package/dist/analyzers/temporal-scorer.js.map +1 -0
- package/dist/cli.d.ts +2 -3
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +275 -113
- package/dist/cli.js.map +1 -1
- package/dist/html-reporter.d.ts +3 -1
- package/dist/html-reporter.d.ts.map +1 -1
- package/dist/html-reporter.js +248 -12
- package/dist/html-reporter.js.map +1 -1
- package/dist/index.d.ts +16 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +63 -4
- package/dist/index.js.map +1 -1
- package/dist/project-summarizer.d.ts +18 -0
- package/dist/project-summarizer.d.ts.map +1 -0
- package/dist/project-summarizer.js +306 -0
- package/dist/project-summarizer.js.map +1 -0
- package/dist/refactor-reporter.js +1 -1
- package/dist/types.d.ts +13 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +12 -3
- package/src/agent-generator/context-enricher.ts +643 -0
- package/src/agent-generator/domain-inferrer.ts +625 -0
- package/src/agent-generator/framework-detector.ts +669 -0
- package/src/agent-generator/index.ts +555 -0
- package/src/agent-generator/stack-detector.ts +103 -0
- package/src/agent-generator/templates/core/agents.ts +1293 -0
- package/src/agent-generator/templates/core/architecture-rules.ts +287 -0
- package/src/agent-generator/templates/core/general-rules.ts +306 -0
- package/src/agent-generator/templates/core/index-md.ts +260 -0
- package/src/agent-generator/templates/core/orchestrator.ts +459 -0
- package/src/agent-generator/templates/core/preflight.ts +215 -0
- package/src/agent-generator/templates/core/quality-gates.ts +256 -0
- package/src/agent-generator/templates/core/security-rules.ts +543 -0
- package/src/agent-generator/templates/core/skills-generator.ts +236 -0
- package/src/agent-generator/templates/core/workflow-fix-bug.ts +239 -0
- package/src/agent-generator/templates/core/workflow-new-feature.ts +323 -0
- package/src/agent-generator/templates/core/workflow-review.ts +106 -0
- package/src/agent-generator/templates/domain/index.ts +1201 -0
- package/src/agent-generator/templates/stack/index.ts +705 -0
- package/src/agent-generator/templates/template-helpers.ts +776 -0
- package/src/agent-generator/types.ts +232 -0
- package/src/analyzer.ts +38 -4
- package/src/analyzers/forecast.ts +496 -0
- package/src/analyzers/git-cache.ts +52 -0
- package/src/analyzers/git-history.ts +488 -0
- package/src/analyzers/index.ts +33 -0
- package/src/analyzers/temporal-scorer.ts +227 -0
- package/src/cli.ts +316 -117
- package/src/html-reporter.ts +263 -13
- package/src/index.ts +92 -9
- package/src/project-summarizer.ts +347 -0
- package/src/refactor-reporter.ts +1 -1
- package/src/types.ts +10 -0
- package/tests/agent-generator.test.ts +411 -0
- package/tests/analyzers-integration.test.ts +174 -0
- package/tests/architect-adapter-enrichment.test.ts +9 -0
- package/tests/context-enricher.test.ts +971 -0
- package/tests/forecast.test.ts +509 -0
- package/tests/framework-detector.test.ts +1172 -0
- package/tests/git-history.test.ts +254 -0
- package/tests/scanner.test.ts +7 -8
- package/tests/scorer.test.ts +588 -0
- package/tests/stack-detector.test.ts +241 -0
- package/tests/template-generation.test.ts +706 -0
- package/tests/template-helpers.test.ts +1152 -0
- package/tests/temporal-scorer.test.ts +307 -0
- package/dist/agent-generator.d.ts +0 -106
- package/dist/agent-generator.d.ts.map +0 -1
- package/dist/agent-generator.js +0 -1398
- package/dist/agent-generator.js.map +0 -1
- package/src/agent-generator.ts +0 -1526
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { StackDetector } from '../src/agent-generator/stack-detector.js';
|
|
2
|
+
import { AnalysisReport } from '../src/types.js';
|
|
3
|
+
|
|
4
|
+
function makeReport(nodes: string[]): AnalysisReport {
|
|
5
|
+
return {
|
|
6
|
+
timestamp: new Date().toISOString(),
|
|
7
|
+
projectInfo: {
|
|
8
|
+
path: '/test',
|
|
9
|
+
name: 'test-project',
|
|
10
|
+
frameworks: [],
|
|
11
|
+
totalFiles: nodes.length,
|
|
12
|
+
totalLines: 1000,
|
|
13
|
+
primaryLanguages: [],
|
|
14
|
+
},
|
|
15
|
+
score: {
|
|
16
|
+
overall: 75,
|
|
17
|
+
components: [],
|
|
18
|
+
breakdown: { modularity: 80, coupling: 70, cohesion: 75, layering: 75 },
|
|
19
|
+
},
|
|
20
|
+
antiPatterns: [],
|
|
21
|
+
layers: [],
|
|
22
|
+
dependencyGraph: { nodes, edges: [] },
|
|
23
|
+
suggestions: [],
|
|
24
|
+
diagram: { mermaid: '', type: 'layer' },
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
describe('StackDetector', () => {
|
|
29
|
+
const detector = new StackDetector();
|
|
30
|
+
|
|
31
|
+
describe('Language Detection', () => {
|
|
32
|
+
it('should detect TypeScript from .ts files', () => {
|
|
33
|
+
const report = makeReport(['src/app.ts', 'src/index.ts']);
|
|
34
|
+
const stack = detector.detect(report);
|
|
35
|
+
|
|
36
|
+
expect(stack.languages).toContain('TypeScript');
|
|
37
|
+
expect(stack.primary).toBe('TypeScript');
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
it('should detect Python from .py files', () => {
|
|
41
|
+
const report = makeReport(['src/main.py', 'src/utils.py']);
|
|
42
|
+
const stack = detector.detect(report);
|
|
43
|
+
|
|
44
|
+
expect(stack.languages).toContain('Python');
|
|
45
|
+
expect(stack.primary).toBe('Python');
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it('should detect Dart from .dart files', () => {
|
|
49
|
+
const report = makeReport(['lib/main.dart', 'lib/app.dart']);
|
|
50
|
+
const stack = detector.detect(report);
|
|
51
|
+
|
|
52
|
+
expect(stack.languages).toContain('Dart');
|
|
53
|
+
expect(stack.primary).toBe('Dart');
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it('should detect Go from .go files', () => {
|
|
57
|
+
const report = makeReport(['main.go', 'handler.go', 'go.mod']);
|
|
58
|
+
const stack = detector.detect(report);
|
|
59
|
+
|
|
60
|
+
expect(stack.languages).toContain('Go');
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('should detect multiple languages', () => {
|
|
64
|
+
const report = makeReport(['src/app.ts', 'scripts/build.py']);
|
|
65
|
+
const stack = detector.detect(report);
|
|
66
|
+
|
|
67
|
+
expect(stack.languages).toContain('TypeScript');
|
|
68
|
+
expect(stack.languages).toContain('Python');
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('should return Unknown for unrecognized extensions', () => {
|
|
72
|
+
const report = makeReport(['file.xyz', 'data.abc']);
|
|
73
|
+
const stack = detector.detect(report);
|
|
74
|
+
|
|
75
|
+
expect(stack.primary).toBe('Unknown');
|
|
76
|
+
expect(stack.languages).toHaveLength(0);
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
describe('Framework Detection', () => {
|
|
81
|
+
it('should detect NestJS from .module.ts files', () => {
|
|
82
|
+
const report = makeReport(['src/app.module.ts', 'src/users/users.service.ts']);
|
|
83
|
+
const stack = detector.detect(report);
|
|
84
|
+
|
|
85
|
+
expect(stack.frameworks).toContain('NestJS');
|
|
86
|
+
});
|
|
87
|
+
|
|
88
|
+
it('should detect Angular from .component.ts files', () => {
|
|
89
|
+
const report = makeReport(['src/app/app.component.ts', 'src/app/app.module.ts']);
|
|
90
|
+
const stack = detector.detect(report);
|
|
91
|
+
|
|
92
|
+
expect(stack.frameworks).toContain('Angular');
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
it('should detect Django from manage.py', () => {
|
|
96
|
+
const report = makeReport(['manage.py', 'app/views.py', 'app/models.py']);
|
|
97
|
+
const stack = detector.detect(report);
|
|
98
|
+
|
|
99
|
+
expect(stack.frameworks).toContain('Django');
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
it('should detect Flutter from .dart files', () => {
|
|
103
|
+
const report = makeReport(['lib/main.dart', 'lib/app.dart']);
|
|
104
|
+
const stack = detector.detect(report);
|
|
105
|
+
|
|
106
|
+
expect(stack.frameworks).toContain('Flutter');
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
it('should detect Spring from pom.xml', () => {
|
|
110
|
+
const report = makeReport(['pom.xml', 'src/main/java/App.java']);
|
|
111
|
+
const stack = detector.detect(report);
|
|
112
|
+
|
|
113
|
+
expect(stack.frameworks).toContain('Spring');
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
it('should detect Next.js from .tsx + next pattern', () => {
|
|
117
|
+
const report = makeReport(['src/pages/index.tsx', 'next.config.js']);
|
|
118
|
+
const stack = detector.detect(report);
|
|
119
|
+
|
|
120
|
+
expect(stack.frameworks).toContain('Next.js');
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
it('should detect Vue from .vue files', () => {
|
|
124
|
+
const report = makeReport(['src/App.vue', 'src/components/Header.vue']);
|
|
125
|
+
const stack = detector.detect(report);
|
|
126
|
+
|
|
127
|
+
expect(stack.frameworks).toContain('Vue');
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
describe('Derived Properties', () => {
|
|
132
|
+
it('should set hasBackend true for TypeScript projects', () => {
|
|
133
|
+
const report = makeReport(['src/app.ts', 'src/controller.ts']);
|
|
134
|
+
const stack = detector.detect(report);
|
|
135
|
+
|
|
136
|
+
expect(stack.hasBackend).toBe(true);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
it('should set hasFrontend true for Angular projects', () => {
|
|
140
|
+
const report = makeReport(['src/app.component.ts', 'src/app.module.ts']);
|
|
141
|
+
const stack = detector.detect(report);
|
|
142
|
+
|
|
143
|
+
expect(stack.hasFrontend).toBe(true);
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
it('should set hasMobile true for Dart projects', () => {
|
|
147
|
+
const report = makeReport(['lib/main.dart']);
|
|
148
|
+
const stack = detector.detect(report);
|
|
149
|
+
|
|
150
|
+
expect(stack.hasMobile).toBe(true);
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
it('should set hasDatabase true when migration files exist', () => {
|
|
154
|
+
const report = makeReport(['src/app.ts', 'src/migration/001_init.ts']);
|
|
155
|
+
const stack = detector.detect(report);
|
|
156
|
+
|
|
157
|
+
expect(stack.hasDatabase).toBe(true);
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
it('should set hasDatabase true when entity files exist', () => {
|
|
161
|
+
const report = makeReport(['src/app.ts', 'src/entity/user.entity.ts']);
|
|
162
|
+
const stack = detector.detect(report);
|
|
163
|
+
|
|
164
|
+
expect(stack.hasDatabase).toBe(true);
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
it('should set hasDatabase false when no DB-related patterns', () => {
|
|
168
|
+
const report = makeReport(['src/app.ts', 'src/utils.ts']);
|
|
169
|
+
const stack = detector.detect(report);
|
|
170
|
+
|
|
171
|
+
expect(stack.hasDatabase).toBe(false);
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
describe('Test Framework Detection', () => {
|
|
176
|
+
it('should return pytest for Python', () => {
|
|
177
|
+
const report = makeReport(['src/main.py']);
|
|
178
|
+
const stack = detector.detect(report);
|
|
179
|
+
|
|
180
|
+
expect(stack.testFramework).toBe('pytest');
|
|
181
|
+
});
|
|
182
|
+
|
|
183
|
+
it('should return flutter_test for Dart', () => {
|
|
184
|
+
const report = makeReport(['lib/main.dart']);
|
|
185
|
+
const stack = detector.detect(report);
|
|
186
|
+
|
|
187
|
+
expect(stack.testFramework).toBe('flutter_test');
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
it('should return Jest for TypeScript (non-Angular)', () => {
|
|
191
|
+
const report = makeReport(['src/app.ts']);
|
|
192
|
+
const stack = detector.detect(report);
|
|
193
|
+
|
|
194
|
+
expect(stack.testFramework).toBe('Jest');
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
it('should return Jest + Jasmine for Angular', () => {
|
|
198
|
+
const report = makeReport(['src/app.component.ts']);
|
|
199
|
+
const stack = detector.detect(report);
|
|
200
|
+
|
|
201
|
+
expect(stack.testFramework).toBe('Jest + Jasmine');
|
|
202
|
+
});
|
|
203
|
+
|
|
204
|
+
it('should return go test for Go', () => {
|
|
205
|
+
const report = makeReport(['main.go']);
|
|
206
|
+
const stack = detector.detect(report);
|
|
207
|
+
|
|
208
|
+
expect(stack.testFramework).toBe('go test');
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
describe('Package Manager Detection', () => {
|
|
213
|
+
it('should return pip for Python', () => {
|
|
214
|
+
const report = makeReport(['src/main.py']);
|
|
215
|
+
const stack = detector.detect(report);
|
|
216
|
+
|
|
217
|
+
expect(stack.packageManager).toBe('pip');
|
|
218
|
+
});
|
|
219
|
+
|
|
220
|
+
it('should return npm for TypeScript', () => {
|
|
221
|
+
const report = makeReport(['src/app.ts']);
|
|
222
|
+
const stack = detector.detect(report);
|
|
223
|
+
|
|
224
|
+
expect(stack.packageManager).toBe('npm');
|
|
225
|
+
});
|
|
226
|
+
|
|
227
|
+
it('should return pub for Dart', () => {
|
|
228
|
+
const report = makeReport(['lib/main.dart']);
|
|
229
|
+
const stack = detector.detect(report);
|
|
230
|
+
|
|
231
|
+
expect(stack.packageManager).toBe('pub');
|
|
232
|
+
});
|
|
233
|
+
|
|
234
|
+
it('should return cargo for Rust', () => {
|
|
235
|
+
const report = makeReport(['src/main.rs', 'Cargo.toml']);
|
|
236
|
+
const stack = detector.detect(report);
|
|
237
|
+
|
|
238
|
+
expect(stack.packageManager).toBe('cargo');
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
});
|