@specverse/engines 5.0.2 → 5.2.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 (116) hide show
  1. package/assets/prompts/core/standard/default/analyse.prompt.yaml +5 -5
  2. package/assets/prompts/core/standard/default/app-demo.prompt.yaml +21 -1
  3. package/assets/prompts/core/standard/default/behavior.prompt.yaml +150 -0
  4. package/assets/prompts/core/standard/default/create.prompt.yaml +3 -3
  5. package/assets/prompts/core/standard/default/materialise.prompt.yaml +804 -774
  6. package/assets/prompts/core/standard/default/realize.prompt.yaml +581 -544
  7. package/assets/prompts/core/standard/v9/analyse.prompt.yaml +5 -5
  8. package/assets/prompts/core/standard/v9/app-demo.prompt.yaml +233 -0
  9. package/assets/prompts/core/standard/v9/behavior.prompt.yaml +33 -9
  10. package/assets/prompts/core/standard/v9/create.prompt.yaml +3 -3
  11. package/assets/prompts/core/standard/v9/materialise.prompt.yaml +804 -774
  12. package/assets/prompts/core/standard/v9/realize.prompt.yaml +581 -544
  13. package/dist/ai/commands/fill.d.ts.map +1 -1
  14. package/dist/ai/commands/fill.js +16 -7
  15. package/dist/ai/commands/fill.js.map +1 -1
  16. package/dist/ai/commands/template.d.ts.map +1 -1
  17. package/dist/ai/commands/template.js +17 -8
  18. package/dist/ai/commands/template.js.map +1 -1
  19. package/dist/bundles/deriveCatalog.d.ts +18 -0
  20. package/dist/bundles/deriveCatalog.d.ts.map +1 -0
  21. package/dist/bundles/deriveCatalog.js +263 -0
  22. package/dist/bundles/deriveCatalog.js.map +1 -0
  23. package/dist/bundles/index.d.ts +15 -0
  24. package/dist/bundles/index.d.ts.map +1 -0
  25. package/dist/bundles/index.js +15 -0
  26. package/dist/bundles/index.js.map +1 -0
  27. package/dist/bundles/types.d.ts +53 -0
  28. package/dist/bundles/types.d.ts.map +1 -0
  29. package/dist/bundles/types.js +22 -0
  30. package/dist/bundles/types.js.map +1 -0
  31. package/dist/bundles/validate.d.ts +55 -0
  32. package/dist/bundles/validate.d.ts.map +1 -0
  33. package/dist/bundles/validate.js +471 -0
  34. package/dist/bundles/validate.js.map +1 -0
  35. package/dist/inference/quint-transpiler.js +2 -2
  36. package/dist/inference/quint-transpiler.js.map +1 -1
  37. package/dist/libs/instance-factories/applications/templates/react/runtime-package-json-generator.js +1 -1
  38. package/dist/libs/instance-factories/cli/templates/commander/command-generator.js +227 -0
  39. package/dist/libs/instance-factories/tools/templates/mcp/mcp-server-generator.js +295 -14
  40. package/libs/instance-factories/applications/templates/react/runtime-package-json-generator.ts +1 -1
  41. package/libs/instance-factories/cli/templates/commander/command-generator.ts +227 -0
  42. package/libs/instance-factories/tools/templates/mcp/mcp-server-generator.ts +328 -15
  43. package/package.json +9 -5
  44. package/assets/examples/09-api/ai-spec.yaml +0 -194
  45. package/assets/examples/09-api/converted.yaml +0 -95
  46. package/assets/examples/09-api/diagram-architecture.mmd +0 -10
  47. package/assets/examples/09-api/diagram-er.mmd +0 -10
  48. package/assets/examples/09-api/documentation.html +0 -104
  49. package/assets/examples/09-api/documentation.md +0 -95
  50. package/assets/examples/09-api/inferred-spec.yaml +0 -420
  51. package/assets/examples/09-api/openapi.json +0 -61
  52. package/assets/examples/10-api/README.md +0 -216
  53. package/assets/examples/10-api/ai-spec.yaml +0 -194
  54. package/assets/examples/10-api/converted.yaml +0 -96
  55. package/assets/examples/10-api/diagram-architecture.mmd +0 -10
  56. package/assets/examples/10-api/diagram-er.mmd +0 -10
  57. package/assets/examples/10-api/documentation.html +0 -104
  58. package/assets/examples/10-api/documentation.md +0 -95
  59. package/assets/examples/10-api/inferred-spec.yaml +0 -7
  60. package/assets/examples/10-api/metadata.yaml +0 -89
  61. package/assets/examples/10-api/openapi.json +0 -61
  62. package/assets/examples/10-api/package-integration-test.js +0 -177
  63. package/assets/examples/10-api/usage-example.js +0 -323
  64. package/assets/examples/10-api/usage-example.ts +0 -363
  65. package/assets/examples/10-api/workflow-test.js +0 -113
  66. package/assets/examples/validate-examples-with-expected-failures.cjs +0 -328
  67. package/assets/examples/validate-examples.cjs +0 -225
  68. package/assets/prompts/MOVED.md +0 -35
  69. package/assets/prompts/SUMMARY-v8-PROMOTION.md +0 -445
  70. package/assets/prompts/core/CHANGELOG.md +0 -158
  71. package/assets/prompts/core/MIGRATION-v6-to-v7.md +0 -379
  72. package/assets/prompts/core/base-terminal-prompt.md +0 -201
  73. package/assets/prompts/core/examples/example-usage.ts +0 -140
  74. package/assets/prompts/core/schemas/prompt.schema.json +0 -309
  75. package/assets/prompts/core/schemas/prompt.schema.yaml +0 -229
  76. package/assets/prompts/core/standard/archive/v1/analyse.prompt.yaml +0 -259
  77. package/assets/prompts/core/standard/archive/v1/create.prompt.yaml +0 -302
  78. package/assets/prompts/core/standard/archive/v1/materialise.prompt.yaml +0 -328
  79. package/assets/prompts/core/standard/archive/v1/realize.prompt.yaml +0 -606
  80. package/assets/prompts/core/standard/archive/v2/README.md +0 -110
  81. package/assets/prompts/core/standard/archive/v2/analyse.prompt.yaml +0 -151
  82. package/assets/prompts/core/standard/archive/v2/create.prompt.yaml +0 -151
  83. package/assets/prompts/core/standard/archive/v2/materialise.prompt.yaml +0 -132
  84. package/assets/prompts/core/standard/archive/v2/realize.prompt.yaml +0 -147
  85. package/assets/prompts/core/standard/archive/v3/README.md +0 -279
  86. package/assets/prompts/core/standard/archive/v3/analyse.prompt.yaml +0 -309
  87. package/assets/prompts/core/standard/archive/v3/create.prompt.yaml +0 -351
  88. package/assets/prompts/core/standard/archive/v3/materialise.prompt.yaml +0 -247
  89. package/assets/prompts/core/standard/archive/v3/realize.prompt.yaml +0 -344
  90. package/assets/prompts/core/standard/archive/v4/README.md +0 -79
  91. package/assets/prompts/core/standard/archive/v4/analyse.prompt.yaml +0 -204
  92. package/assets/prompts/core/standard/archive/v4/create.prompt.yaml +0 -185
  93. package/assets/prompts/core/standard/archive/v5/README.md +0 -224
  94. package/assets/prompts/core/standard/archive/v5/analyse.prompt.yaml +0 -209
  95. package/assets/prompts/core/standard/archive/v5/create.prompt.yaml +0 -225
  96. package/assets/prompts/core/standard/archive/v5/materialise.prompt.yaml +0 -242
  97. package/assets/prompts/core/standard/archive/v5/realize.prompt.yaml +0 -336
  98. package/assets/prompts/core/standard/archive/v6/README.md +0 -187
  99. package/assets/prompts/core/standard/archive/v6/analyse.prompt.yaml +0 -219
  100. package/assets/prompts/core/standard/archive/v6/create.prompt.yaml +0 -180
  101. package/assets/prompts/core/standard/archive/v6/materialise.prompt.yaml +0 -203
  102. package/assets/prompts/core/standard/archive/v6/realize.prompt.yaml +0 -215
  103. package/assets/prompts/core/standard/archive/v7/analyse.prompt.nick.yaml +0 -144
  104. package/assets/prompts/core/standard/archive/v7/analyse.prompt.old.yaml +0 -146
  105. package/assets/prompts/core/standard/archive/v7/analyse.prompt.yaml +0 -129
  106. package/assets/prompts/core/standard/archive/v7/create.prompt.yaml +0 -146
  107. package/assets/prompts/core/standard/archive/v7/materialise.prompt.yaml +0 -297
  108. package/assets/prompts/core/standard/archive/v7/realize.prompt.yaml +0 -294
  109. package/assets/prompts/core/standard/archive/v8/README.md +0 -400
  110. package/assets/prompts/core/standard/archive/v8/analyse.prompt.yaml +0 -185
  111. package/assets/prompts/core/standard/archive/v8/create.prompt.yaml +0 -203
  112. package/assets/prompts/core/standard/archive/v8/materialise.prompt.yaml +0 -297
  113. package/assets/prompts/core/standard/archive/v8/realize.prompt.yaml +0 -294
  114. package/assets/prompts/templates/api-orchestrator-template.yaml +0 -188
  115. package/assets/prompts/templates/claude-integration-template.md +0 -121
  116. package/assets/prompts/templates/terminal-prompt-template.md +0 -97
@@ -1,363 +0,0 @@
1
- /**
2
- * SpecVerse TypeScript/JavaScript API Usage Examples
3
- *
4
- * This file demonstrates how to use SpecVerse functionality programmatically
5
- * instead of through the CLI.
6
- */
7
-
8
- import {
9
- // Parser and AST
10
- SpecVerseParser,
11
- ParseResult,
12
- SpecVerseAST,
13
-
14
- // Inference Engine
15
- LogicalInferenceEngine,
16
- InferenceEngineConfig,
17
-
18
- // Generators
19
- AIViewGenerator,
20
- UMLGenerator,
21
- DocumentationGenerator,
22
- UnifiedDiagramGenerator,
23
-
24
- // Types
25
- ModelSpec,
26
- ControllerSpec,
27
- ServiceSpec,
28
- EventSpec,
29
- ViewSpec
30
- } from '@specverse/lang';
31
-
32
- import { readFileSync, writeFileSync } from 'fs';
33
- import * as yaml from 'js-yaml';
34
-
35
- // ============================================
36
- // 1. PARSING SPECVERSE FILES
37
- // ============================================
38
-
39
- async function parseSpecification(filePath: string): Promise<SpecVerseAST | undefined> {
40
- // Load the schema (in real usage, this would be from node_modules/@specverse/lang/schema/)
41
- const schema = JSON.parse(readFileSync('node_modules/@specverse/lang/schema/SPECVERSE-SCHEMA.json', 'utf8'));
42
-
43
- // Create parser instance
44
- const parser = new SpecVerseParser(schema);
45
-
46
- // Read and parse the file
47
- const content = readFileSync(filePath, 'utf8');
48
- const result: ParseResult = parser.parseContent(content, filePath);
49
-
50
- // Check for errors
51
- if (result.errors.length > 0) {
52
- console.error('Parse errors:', result.errors);
53
- return undefined;
54
- }
55
-
56
- // Handle warnings if any
57
- if (result.warnings && result.warnings.length > 0) {
58
- console.warn('Parse warnings:', result.warnings);
59
- }
60
-
61
- console.log('āœ… Successfully parsed:', filePath);
62
- return result.ast;
63
- }
64
-
65
- // ============================================
66
- // 2. USING THE INFERENCE ENGINE
67
- // ============================================
68
-
69
- async function runInference(ast: SpecVerseAST): Promise<any> {
70
- // Configure inference options
71
- const config: Partial<InferenceEngineConfig> = {
72
- logical: {
73
- generateControllers: true,
74
- generateServices: true,
75
- generateEvents: true,
76
- generateViews: true,
77
- generateTypes: true,
78
- },
79
- rules: {
80
- logicalRulesPath: 'node_modules/@specverse/lang/dist/inference-engine/rules/logical',
81
- deploymentRulesPath: 'node_modules/@specverse/lang/dist/inference-engine/rules/deployment'
82
- }
83
- };
84
-
85
- // Create inference engine instance
86
- const inferenceEngine = new LogicalInferenceEngine(config);
87
-
88
- // Extract models from AST
89
- const models = ast.components.flatMap(c => c.models);
90
-
91
- // Load rules first
92
- console.log('šŸ“‹ Loading inference rules...');
93
- const rulesValidation = await inferenceEngine.loadRules();
94
-
95
- if (!rulesValidation.valid) {
96
- console.error('āŒ Failed to load inference rules:', rulesValidation.errors.map(e => e.message));
97
- return undefined;
98
- }
99
-
100
- // Run inference on models
101
- const componentName = 'GeneratedComponent';
102
- const inferenceResult = await inferenceEngine.inferLogicalSpecification(models, componentName);
103
-
104
- console.log('šŸ“Š Inference Results:');
105
- console.log(' Validation:', inferenceResult.validation.valid ? 'āœ…' : 'āŒ');
106
- console.log(' Models processed:', inferenceResult.statistics.modelsProcessed);
107
- console.log(' Controllers generated:', inferenceResult.statistics.controllersGenerated);
108
- console.log(' Services generated:', inferenceResult.statistics.servicesGenerated);
109
- console.log(' Events generated:', inferenceResult.statistics.eventsGenerated);
110
- console.log(' Views generated:', inferenceResult.statistics.viewsGenerated);
111
-
112
- if (!inferenceResult.validation.valid) {
113
- console.error(' Errors:', inferenceResult.validation.errors.map(e => e.message));
114
- }
115
-
116
- return inferenceResult;
117
- }
118
-
119
- // ============================================
120
- // 3. GENERATING AI-OPTIMIZED SPECIFICATIONS
121
- // ============================================
122
-
123
- async function generateAIView(ast: SpecVerseAST): Promise<void> {
124
- const generator = new AIViewGenerator();
125
-
126
- // Generate AI-optimized specification
127
- const aiSpec = generator.generate(ast);
128
-
129
- // Convert to YAML for readability
130
- const yamlOutput = yaml.dump(aiSpec, {
131
- indent: 2,
132
- lineWidth: 120,
133
- noRefs: true
134
- });
135
-
136
- writeFileSync('output/ai-optimized.yaml', yamlOutput);
137
- console.log('āœ… AI-optimized specification generated');
138
- }
139
-
140
- // ============================================
141
- // 4. GENERATING UML DIAGRAMS
142
- // ============================================
143
-
144
- async function generateUMLDiagrams(ast: SpecVerseAST): Promise<void> {
145
- try {
146
- const generator = new UMLGenerator();
147
-
148
- // Generate different types of diagrams with proper options
149
- const diagramTypes = [
150
- { type: 'er' as const, includeAttributes: true, includeRelationships: true },
151
- { type: 'sequence' as const, includeEvents: true },
152
- { type: 'architecture' as const, includeControllers: true, includeServices: true, includeEvents: true },
153
- { type: 'lifecycle' as const }
154
- ];
155
-
156
- // Generate and save diagrams
157
- for (const options of diagramTypes) {
158
- const content = generator.generate(ast, options);
159
- if (content) {
160
- writeFileSync(`output/diagram-${options.type}.mmd`, content);
161
- console.log(`āœ… Generated ${options.type} diagram`);
162
- }
163
- }
164
- } catch (error) {
165
- console.warn('āš ļø UML diagram generation failed:', error instanceof Error ? error.message : String(error));
166
- }
167
- }
168
-
169
- // ============================================
170
- // 5. GENERATING DOCUMENTATION
171
- // ============================================
172
-
173
- async function generateDocumentation(ast: SpecVerseAST): Promise<void> {
174
- try {
175
- const generator = new DocumentationGenerator();
176
-
177
- // Generate markdown documentation
178
- const markdown = generator.generate(ast, {
179
- format: 'markdown',
180
- includeTableOfContents: true,
181
- includeExamples: true,
182
- includeDiagrams: false
183
- });
184
- writeFileSync('output/documentation.md', markdown);
185
-
186
- // Generate HTML documentation
187
- const html = generator.generate(ast, {
188
- format: 'html',
189
- includeTableOfContents: true,
190
- includeExamples: true
191
- });
192
- writeFileSync('output/documentation.html', html);
193
-
194
- // Generate OpenAPI specification
195
- const openapi = generator.generate(ast, {
196
- format: 'openapi',
197
- baseUrl: 'https://api.example.com'
198
- });
199
- writeFileSync('output/openapi.json', openapi);
200
-
201
- console.log('āœ… Documentation generated (Markdown, HTML, OpenAPI)');
202
- } catch (error) {
203
- console.warn('āš ļø Documentation generation failed:', error instanceof Error ? error.message : String(error));
204
- }
205
- }
206
-
207
- // ============================================
208
- // 6. WORKING WITH MERMAID DIAGRAMS (V3.1)
209
- // ============================================
210
-
211
- async function generateMermaidDiagrams(filePath: string): Promise<void> {
212
- const generator = new UnifiedDiagramGenerator();
213
-
214
- // Generate all diagram types
215
- const outputDir = 'output/diagrams';
216
- await generator.generateFromFile(filePath, outputDir);
217
-
218
- console.log('āœ… Mermaid diagrams generated in:', outputDir);
219
- }
220
-
221
- // ============================================
222
- // 7. CUSTOM PROCESSING EXAMPLE
223
- // ============================================
224
-
225
- async function customProcessing(ast: SpecVerseAST): Promise<void> {
226
- // Extract all models
227
- const allModels: ModelSpec[] = ast.components.flatMap(c => c.models);
228
-
229
- // Extract all controllers
230
- const allControllers: ControllerSpec[] = ast.components.flatMap(c => c.controllers);
231
-
232
- // Extract all events
233
- const allEvents: EventSpec[] = ast.components.flatMap(c => c.events);
234
-
235
- // Custom analysis
236
- console.log('\nšŸ“Š Custom Analysis:');
237
- console.log('Total models:', allModels.length);
238
- console.log('Models with lifecycles:', allModels.filter(m => m.lifecycle).length);
239
- console.log('Total endpoints:', allControllers.flatMap(c => c.actions).length);
240
- console.log('Total events:', allEvents.length);
241
-
242
- // Generate custom output
243
- const customOutput = {
244
- summary: {
245
- modelCount: allModels.length,
246
- controllerCount: allControllers.length,
247
- eventCount: allEvents.length,
248
- },
249
- models: allModels.map(m => ({
250
- name: m.name,
251
- attributeCount: Object.keys(m.attributes || {}).length,
252
- hasLifecycle: !!m.lifecycle,
253
- relationshipCount: m.relationships?.length || 0
254
- })),
255
- controllers: allControllers.map(c => ({
256
- name: c.name,
257
- actionCount: c.actions.length,
258
- model: c.model
259
- }))
260
- };
261
-
262
- writeFileSync('output/custom-analysis.json', JSON.stringify(customOutput, null, 2));
263
- console.log('āœ… Custom analysis saved');
264
- }
265
-
266
- // ============================================
267
- // 8. VALIDATION ONLY
268
- // ============================================
269
-
270
- function validateSpecification(filePath: string): boolean {
271
- const schema = JSON.parse(readFileSync('node_modules/@specverse/lang/schema/SPECVERSE-SCHEMA.json', 'utf8'));
272
- const parser = new SpecVerseParser(schema);
273
-
274
- const content = readFileSync(filePath, 'utf8');
275
- const result = parser.parseContent(content, filePath);
276
-
277
- if (result.errors.length === 0) {
278
- console.log('āœ… Specification is valid');
279
- return true;
280
- } else {
281
- console.error('āŒ Validation errors:');
282
- result.errors.forEach(error => console.error(' -', error));
283
- return false;
284
- }
285
- }
286
-
287
- // ============================================
288
- // 9. PROCESSING SPECLY TO YAML
289
- // ============================================
290
-
291
- function processSpeclyToYaml(speclyPath: string, outputPath: string): void {
292
- const schema = JSON.parse(readFileSync('node_modules/@specverse/lang/schema/SPECVERSE-SCHEMA.json', 'utf8'));
293
- const parser = new SpecVerseParser(schema);
294
-
295
- const content = readFileSync(speclyPath, 'utf8');
296
- const result = parser.processToYaml(content);
297
-
298
- if (result.errors.length > 0) {
299
- console.error('āŒ Processing errors:', result.errors);
300
- return;
301
- }
302
-
303
- writeFileSync(outputPath, result.yaml);
304
- console.log('āœ… Processed to YAML:', outputPath);
305
- }
306
-
307
- // ============================================
308
- // MAIN EXAMPLE USAGE
309
- // ============================================
310
-
311
- async function main() {
312
- try {
313
- const specFile = 'examples/01-fundamentals/01-01-basic-model.specly';
314
-
315
- // 1. Parse the specification
316
- const ast = await parseSpecification(specFile);
317
- if (!ast) {
318
- console.error('Failed to parse specification');
319
- return;
320
- }
321
-
322
- // 2. Run inference to generate complete architecture
323
- const inferenceResult = await runInference(ast);
324
-
325
- // 3. Generate various outputs
326
- await generateAIView(ast);
327
- await generateUMLDiagrams(ast);
328
- await generateDocumentation(ast);
329
- await generateMermaidDiagrams(specFile);
330
-
331
- // 4. Custom processing
332
- await customProcessing(ast);
333
-
334
- // 5. Process .specly to .yaml
335
- processSpeclyToYaml(specFile, 'output/processed.yaml');
336
-
337
- console.log('\n✨ All operations completed successfully!');
338
-
339
- } catch (error) {
340
- console.error('Error:', error);
341
- }
342
- }
343
-
344
- // Run if this file is executed directly
345
- if (import.meta.url === `file://${process.argv[1]}`) {
346
- main();
347
- }
348
-
349
- // ============================================
350
- // EXPORTS FOR USE IN OTHER MODULES
351
- // ============================================
352
-
353
- export {
354
- parseSpecification,
355
- runInference,
356
- generateAIView,
357
- generateUMLDiagrams,
358
- generateDocumentation,
359
- generateMermaidDiagrams,
360
- customProcessing,
361
- validateSpecification,
362
- processSpeclyToYaml
363
- };
@@ -1,113 +0,0 @@
1
- /**
2
- * SpecVerse API Workflow Test
3
- *
4
- * Focused end-to-end workflow test for the SpecVerse API
5
- * This is a minimal, streamlined test extracted from test-specverse-api
6
- */
7
-
8
- import { SpecVerseParser, LogicalInferenceEngine } from '../../dist/index.js';
9
- import { readFileSync, writeFileSync } from 'fs';
10
-
11
- // Simple test specification
12
- const testSpec = `components:
13
- UserManagement:
14
- version: "1.0.0"
15
- description: "User management system"
16
-
17
- models:
18
- User:
19
- description: "User model for API testing"
20
- attributes:
21
- id: UUID required
22
- name: String required
23
- email: Email unique required
24
- created_at: DateTime auto=now
25
-
26
- lifecycles:
27
- status:
28
- flow: inactive -> active -> suspended
29
-
30
- deployments: {}`;
31
-
32
- async function testFullWorkflow() {
33
- console.log('🧪 Testing full API workflow...');
34
-
35
- try {
36
- // 1. Parse the spec
37
- console.log('1ļøāƒ£ Parsing specification...');
38
-
39
- const schema = JSON.parse(readFileSync('schema/SPECVERSE-SCHEMA.json', 'utf8'));
40
- const parser = new SpecVerseParser(schema);
41
- const result = parser.parseContent(testSpec, 'test.specly');
42
-
43
- if (result.errors.length > 0) {
44
- throw new Error('Parse failed: ' + result.errors.map(e => e.message).join(', '));
45
- }
46
-
47
- const ast = result.ast;
48
- console.log('āœ… Parsed successfully');
49
-
50
- // 2. Run inference
51
- console.log('2ļøāƒ£ Running inference...');
52
- const config = {
53
- logical: {
54
- generateControllers: true,
55
- generateServices: true,
56
- generateEvents: true,
57
- generateViews: true,
58
- generateTypes: true
59
- },
60
- rules: {
61
- logicalRulesPath: 'dist/inference-engine/rules/logical',
62
- deploymentRulesPath: 'dist/inference-engine/rules/deployment'
63
- }
64
- };
65
-
66
- const engine = new LogicalInferenceEngine(config);
67
- const models = ast.components.flatMap(c => c.models);
68
-
69
- // Load rules
70
- const rulesResult = await engine.loadRules();
71
- if (!rulesResult.valid) {
72
- throw new Error('Failed to load rules: ' + rulesResult.errors.map(e => e.message).join(', '));
73
- }
74
-
75
- // Run inference
76
- const inferenceResult = await engine.inferLogicalSpecification(models, 'TestComponent');
77
-
78
- console.log('āœ… Inference completed!');
79
- console.log(' Generated Controllers:', inferenceResult.statistics.controllersGenerated || 0);
80
- console.log(' Generated Services:', inferenceResult.statistics.servicesGenerated || 0);
81
- console.log(' Generated Events:', inferenceResult.statistics.eventsGenerated || 0);
82
- console.log(' Generated Views:', inferenceResult.statistics.viewsGenerated || 0);
83
-
84
- if (inferenceResult.validation.valid) {
85
- console.log('āœ… Generated specification is valid!');
86
- console.log('šŸŽ‰ FULL API WORKFLOW SUCCESS!');
87
- return true;
88
- } else {
89
- console.log('āš ļø Generated specification has warnings:', inferenceResult.validation.errors.length);
90
- inferenceResult.validation.errors.forEach(error => {
91
- console.log(' -', error.message);
92
- });
93
- return false;
94
- }
95
-
96
- } catch (error) {
97
- console.error('āŒ Workflow failed:', error.message);
98
- return false;
99
- }
100
- }
101
-
102
- // Export for use in tests
103
- export { testFullWorkflow };
104
-
105
- // Run if executed directly
106
- if (import.meta.url === `file://${process.argv[1]}`) {
107
- testFullWorkflow()
108
- .then(success => process.exit(success ? 0 : 1))
109
- .catch(error => {
110
- console.error('Unexpected error:', error);
111
- process.exit(1);
112
- });
113
- }