@aiready/cli 0.14.9 → 0.14.10

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.
@@ -1,29 +1,28 @@
1
-
2
- 
3
- > @aiready/cli@0.14.9 build /Users/pengcao/projects/aiready/packages/cli
4
- > tsup src/index.ts src/cli.ts --format cjs,esm
5
-
6
- CLI Building entry: src/cli.ts, src/index.ts
7
- CLI Using tsconfig: tsconfig.json
8
- CLI tsup v8.5.1
9
- CLI Target: es2020
10
- CJS Build start
11
- ESM Build start
12
-
13
-  WARN  ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta] 10:14:43 am
14
-
15
- src/cli.ts:29:31:
16
-  29 │ return dirname(fileURLToPath(import.meta.url));
17
- ╵ ~~~~~~~~~~~
18
-
19
- You need to set the output format to "esm" for "import.meta" to work correctly.
20
-
21
-
22
-
23
- ESM dist/index.mjs 170.00 B
24
- ESM dist/cli.mjs 70.91 KB
25
- ESM dist/chunk-VOKP7FGM.mjs 9.52 KB
26
- ESM ⚡️ Build success in 36ms
27
- CJS dist/cli.js 84.70 KB
28
- CJS dist/index.js 10.62 KB
29
- CJS ⚡️ Build success in 36ms
1
+
2
+ > @aiready/cli@0.14.10 build /Users/pengcao/projects/aiready/packages/cli
3
+ > tsup src/index.ts src/cli.ts --format cjs,esm
4
+
5
+ CLI Building entry: src/cli.ts, src/index.ts
6
+ CLI Using tsconfig: tsconfig.json
7
+ CLI tsup v8.5.1
8
+ CLI Target: es2020
9
+ CJS Build start
10
+ ESM Build start
11
+
12
+ WARN ▲ [WARNING] "import.meta" is not available with the "cjs" output format and will be empty [empty-import-meta]
13
+
14
+ src/cli.ts:29:31:
15
+  29 │ return dirname(fileURLToPath(import.meta.url));
16
+ ~~~~~~~~~~~
17
+
18
+ You need to set the output format to "esm" for "import.meta" to work correctly.
19
+
20
+
21
+
22
+ CJS dist/cli.js 84.95 KB
23
+ CJS dist/index.js 10.87 KB
24
+ CJS ⚡️ Build success in 42ms
25
+ ESM dist/index.mjs 170.00 B
26
+ ESM dist/chunk-JRRBBFYB.mjs 9.77 KB
27
+ ESM dist/cli.mjs 70.91 KB
28
+ ESM ⚡️ Build success in 42ms
@@ -1,76 +1,74 @@
1
-
2
- 
3
- > @aiready/cli@0.14.8 test /Users/pengcao/projects/aiready/packages/cli
4
- > vitest run
5
-
6
- [?25l
7
-  RUN  v4.0.18 /Users/pengcao/projects/aiready/packages/cli
8
-
9
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should generate HTML from specified report
10
- Building graph from report...
11
-
12
- ✓ src/commands/__tests__/testability.test.ts (2 tests) 17ms
13
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should generate HTML from specified report
14
- Generating HTML...
15
- ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
16
-
17
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should find latest report if none specified
18
- Found latest report: latest.json
19
- Building graph from report...
20
-
21
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should find latest report if none specified
22
- Generating HTML...
23
- ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
24
-
25
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should handle missing reports
26
- 
27
- Generate a report with:
28
- aiready scan --output json
29
-
30
- Or specify a custom report:
31
- aiready visualise --report <path-to-report.json>
32
-
33
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should attempt to open visualization if requested
34
- Building graph from report...
35
-
36
- stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should attempt to open visualization if requested
37
- Generating HTML...
38
- ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
39
-
40
- ✓ src/commands/__tests__/visualize.test.ts (4 tests) 59ms
41
- ✓ src/commands/__tests__/deps-health.test.ts (1 test) 63ms
42
- ✓ src/commands/__tests__/doc-drift.test.ts (1 test) 60ms
43
- ✓ src/commands/__tests__/ai-signal-clarity.test.ts (1 test) 58ms
44
- ✓ src/commands/__tests__/agent-grounding.test.ts (1 test) 57ms
45
- stdout | src/commands/__tests__/upload.test.ts > Upload CLI Action > should fail if API key is missing
46
-  Set AIREADY_API_KEY environment variable or use --api-key flag.
47
- Get an API key from https://platform.getaiready.dev/dashboard
48
- 🚀 Uploading report to https://dev.platform.getaiready.dev...
49
- Reading report from /Users/pengcao/projects/aiready/packages/cli/report.json...
50
- Successfully parsed report JSON.
51
-
52
- stdout | src/commands/__tests__/upload.test.ts > Upload CLI Action > should fail if API key is missing
53
- 
54
- Upload successful! (0.00s)
55
- View results: https://dev.platform.getaiready.dev/dashboard
56
- Analysis ID: 123
57
- Score: 80/100
58
-
59
- ✓ src/commands/__tests__/upload.test.ts (2 tests) 11ms
60
- ✓ src/commands/__tests__/init.test.ts (3 tests) 9ms
61
- ✓ src/commands/__tests__/consistency.test.ts (4 tests) 4ms
62
- ✓ src/utils/__tests__/helpers.test.ts (3 tests) 2ms
63
- ✓ src/commands/__tests__/scan.test.ts (6 tests) 98ms
64
- ✓ src/commands/__tests__/extra-commands.test.ts (8 tests) 113ms
65
- ✓ src/__tests__/unified.test.ts (4 tests) 3ms
66
- ✓ src/__tests__/cli.test.ts (3 tests) 3798ms
67
- ✓ should run unified analysis with both tools  3797ms
68
- ✓ src/__tests__/config-shape.test.ts (3 tests) 3799ms
69
- ✓ should generate a strictly portable AIReadyConfig in summary  3798ms
70
-
71
-  Test Files  15 passed (15)
72
-  Tests  46 passed (46)
73
-  Start at  10:12:44
74
-  Duration  5.54s (transform 3.64s, setup 0ms, import 10.00s, tests 8.15s, environment 2ms)
75
-
76
- [?25h
1
+
2
+ > @aiready/cli@0.14.9 test /Users/pengcao/projects/aiready/packages/cli
3
+ > vitest run
4
+
5
+
6
+  RUN  v4.0.18 /Users/pengcao/projects/aiready/packages/cli
7
+
8
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should generate HTML from specified report
9
+ Building graph from report...
10
+
11
+ ✓ src/commands/__tests__/agent-grounding.test.ts (1 test) 11ms
12
+ ✓ src/commands/__tests__/testability.test.ts (2 tests) 12ms
13
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should generate HTML from specified report
14
+ Generating HTML...
15
+ ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
16
+
17
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should find latest report if none specified
18
+ Found latest report: latest.json
19
+ Building graph from report...
20
+
21
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should find latest report if none specified
22
+ Generating HTML...
23
+ ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
24
+
25
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should handle missing reports
26
+ 
27
+ Generate a report with:
28
+ aiready scan --output json
29
+
30
+ Or specify a custom report:
31
+ aiready visualise --report <path-to-report.json>
32
+
33
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should attempt to open visualization if requested
34
+ Building graph from report...
35
+
36
+ stdout | src/commands/__tests__/visualize.test.ts > Visualize CLI Action > should attempt to open visualization if requested
37
+ Generating HTML...
38
+ ✅ Visualization written to: /Users/pengcao/projects/aiready/packages/cli/visualization.html
39
+
40
+ ✓ src/commands/__tests__/doc-drift.test.ts (1 test) 7ms
41
+ ✓ src/commands/__tests__/ai-signal-clarity.test.ts (1 test) 8ms
42
+ ✓ src/commands/__tests__/visualize.test.ts (4 tests) 27ms
43
+ ✓ src/commands/__tests__/deps-health.test.ts (1 test) 9ms
44
+ stdout | src/commands/__tests__/upload.test.ts > Upload CLI Action > should fail if API key is missing
45
+  Set AIREADY_API_KEY environment variable or use --api-key flag.
46
+ Get an API key from https://platform.getaiready.dev/dashboard
47
+ 🚀 Uploading report to https://dev.platform.getaiready.dev...
48
+ Reading report from /Users/pengcao/projects/aiready/packages/cli/report.json...
49
+ Successfully parsed report JSON.
50
+
51
+ stdout | src/commands/__tests__/upload.test.ts > Upload CLI Action > should fail if API key is missing
52
+ 
53
+ ✅ Upload successful! (0.00s)
54
+ View results: https://dev.platform.getaiready.dev/dashboard
55
+ Analysis ID: 123
56
+ Score: 80/100
57
+
58
+ ✓ src/commands/__tests__/upload.test.ts (2 tests) 4ms
59
+ ✓ src/utils/__tests__/helpers.test.ts (3 tests) 2ms
60
+ ✓ src/commands/__tests__/init.test.ts (3 tests) 5ms
61
+ ✓ src/commands/__tests__/consistency.test.ts (4 tests) 4ms
62
+ ✓ src/commands/__tests__/scan.test.ts (6 tests) 94ms
63
+ ✓ src/commands/__tests__/extra-commands.test.ts (8 tests) 122ms
64
+ ✓ src/__tests__/unified.test.ts (4 tests) 3ms
65
+ ✓ src/__tests__/cli.test.ts (3 tests) 4113ms
66
+ ✓ should run unified analysis with both tools  4112ms
67
+ ✓ src/__tests__/config-shape.test.ts (3 tests) 4113ms
68
+ ✓ should generate a strictly portable AIReadyConfig in summary  4112ms
69
+
70
+  Test Files  15 passed (15)
71
+  Tests  46 passed (46)
72
+  Start at  15:39:46
73
+  Duration  5.18s (transform 2.58s, setup 0ms, import 5.99s, tests 8.53s, environment 2ms)
74
+
@@ -0,0 +1,289 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined") return require.apply(this, arguments);
5
+ throw Error('Dynamic require of "' + x + '" is not supported');
6
+ });
7
+
8
+ // src/index.ts
9
+ import {
10
+ ToolRegistry,
11
+ ToolName,
12
+ calculateOverallScore,
13
+ calculateTokenBudget,
14
+ GLOBAL_INFRA_OPTIONS,
15
+ COMMON_FINE_TUNING_OPTIONS,
16
+ initializeParsers
17
+ } from "@aiready/core";
18
+ import "@aiready/pattern-detect";
19
+ import "@aiready/context-analyzer";
20
+ import "@aiready/consistency";
21
+ import "@aiready/ai-signal-clarity";
22
+ import "@aiready/agent-grounding";
23
+ import "@aiready/testability";
24
+ import "@aiready/doc-drift";
25
+ import "@aiready/deps";
26
+ import "@aiready/change-amplification";
27
+ var TOOL_PACKAGE_MAP = {
28
+ [ToolName.PatternDetect]: "@aiready/pattern-detect",
29
+ [ToolName.ContextAnalyzer]: "@aiready/context-analyzer",
30
+ [ToolName.NamingConsistency]: "@aiready/consistency",
31
+ [ToolName.AiSignalClarity]: "@aiready/ai-signal-clarity",
32
+ [ToolName.AgentGrounding]: "@aiready/agent-grounding",
33
+ [ToolName.TestabilityIndex]: "@aiready/testability",
34
+ [ToolName.DocDrift]: "@aiready/doc-drift",
35
+ [ToolName.DependencyHealth]: "@aiready/deps",
36
+ [ToolName.ChangeAmplification]: "@aiready/change-amplification",
37
+ // Aliases handled by registry
38
+ patterns: "@aiready/pattern-detect",
39
+ duplicates: "@aiready/pattern-detect",
40
+ context: "@aiready/context-analyzer",
41
+ fragmentation: "@aiready/context-analyzer",
42
+ consistency: "@aiready/consistency",
43
+ "ai-signal": "@aiready/ai-signal-clarity",
44
+ grounding: "@aiready/agent-grounding",
45
+ testability: "@aiready/testability",
46
+ "deps-health": "@aiready/deps",
47
+ "change-amp": "@aiready/change-amplification"
48
+ };
49
+ function sanitizeConfigRecursive(obj) {
50
+ if (!obj || typeof obj !== "object" || Array.isArray(obj)) return obj;
51
+ const sanitized = {};
52
+ const infraToStrip = [
53
+ "rootDir",
54
+ "onProgress",
55
+ "progressCallback",
56
+ "streamResults",
57
+ "batchSize",
58
+ "useSmartDefaults"
59
+ ];
60
+ for (const [key, value] of Object.entries(obj)) {
61
+ if (infraToStrip.includes(key)) continue;
62
+ if (typeof value === "object" && value !== null && !Array.isArray(value)) {
63
+ sanitized[key] = sanitizeConfigRecursive(value);
64
+ } else {
65
+ sanitized[key] = value;
66
+ }
67
+ }
68
+ return sanitized;
69
+ }
70
+ function sanitizeToolConfig(config) {
71
+ return sanitizeConfigRecursive(config);
72
+ }
73
+ async function analyzeUnified(options) {
74
+ await initializeParsers();
75
+ const startTime = Date.now();
76
+ const requestedTools = options.tools ?? [
77
+ "patterns",
78
+ "context",
79
+ "consistency"
80
+ ];
81
+ const result = {
82
+ summary: {
83
+ totalIssues: 0,
84
+ criticalIssues: 0,
85
+ // Added as per instruction
86
+ majorIssues: 0,
87
+ // Added as per instruction
88
+ totalFiles: 0,
89
+ toolsRun: [],
90
+ executionTime: 0,
91
+ config: options,
92
+ toolConfigs: {}
93
+ }
94
+ };
95
+ for (const toolName of requestedTools) {
96
+ let provider = ToolRegistry.find(toolName);
97
+ if (!provider) {
98
+ const packageName = TOOL_PACKAGE_MAP[toolName] ?? (toolName.startsWith("@aiready/") ? toolName : `@aiready/${toolName}`);
99
+ try {
100
+ await import(packageName);
101
+ provider = ToolRegistry.find(toolName);
102
+ if (provider) {
103
+ console.log(
104
+ `\u2705 Successfully loaded tool provider: ${toolName} from ${packageName}`
105
+ );
106
+ } else {
107
+ console.log(
108
+ `\u26A0\uFE0F Loaded ${packageName} but provider ${toolName} still not found in registry.`
109
+ );
110
+ }
111
+ } catch (err) {
112
+ console.log(
113
+ `\u274C Failed to dynamically load tool ${toolName} (${packageName}):`,
114
+ err.message
115
+ );
116
+ }
117
+ }
118
+ if (!provider) {
119
+ console.warn(
120
+ `\u26A0\uFE0F Warning: Tool provider for '${toolName}' not found. Skipping.`
121
+ );
122
+ continue;
123
+ }
124
+ try {
125
+ const sanitizedOptions = { ...options };
126
+ delete sanitizedOptions.onProgress;
127
+ delete sanitizedOptions.progressCallback;
128
+ const toolOptions = {
129
+ rootDir: options.rootDir
130
+ // Always include rootDir
131
+ };
132
+ [...GLOBAL_INFRA_OPTIONS, ...COMMON_FINE_TUNING_OPTIONS].forEach(
133
+ (key) => {
134
+ if (key in options && key !== "toolConfigs" && key !== "tools") {
135
+ toolOptions[key] = options[key];
136
+ }
137
+ }
138
+ );
139
+ if (options.toolConfigs?.[provider.id]) {
140
+ Object.assign(toolOptions, options.toolConfigs[provider.id]);
141
+ } else if (options.tools && !Array.isArray(options.tools) && typeof options.tools === "object" && options.tools[provider.id]) {
142
+ Object.assign(toolOptions, options.tools[provider.id]);
143
+ } else if (options[provider.id]) {
144
+ Object.assign(toolOptions, options[provider.id]);
145
+ }
146
+ toolOptions.onProgress = (processed, total, message) => {
147
+ if (options.progressCallback) {
148
+ options.progressCallback({
149
+ tool: provider.id,
150
+ processed,
151
+ total,
152
+ message
153
+ });
154
+ }
155
+ };
156
+ const output = await provider.analyze(toolOptions);
157
+ if (output.metadata) {
158
+ output.metadata.config = sanitizeToolConfig(toolOptions);
159
+ }
160
+ if (options.progressCallback) {
161
+ options.progressCallback({ tool: provider.id, data: output });
162
+ }
163
+ result[provider.id] = output;
164
+ result.summary.toolsRun.push(provider.id);
165
+ if (output.summary?.config) {
166
+ result.summary.toolConfigs[provider.id] = sanitizeToolConfig(
167
+ output.summary.config
168
+ );
169
+ } else if (output.metadata?.config) {
170
+ result.summary.toolConfigs[provider.id] = sanitizeToolConfig(
171
+ output.metadata.config
172
+ );
173
+ } else {
174
+ result.summary.toolConfigs[provider.id] = sanitizeToolConfig(toolOptions);
175
+ }
176
+ const toolFiles = output.summary?.totalFiles ?? output.summary?.filesAnalyzed ?? 0;
177
+ if (toolFiles > result.summary.totalFiles) {
178
+ result.summary.totalFiles = toolFiles;
179
+ }
180
+ const issueCount = output.results.reduce(
181
+ (sum, file) => sum + (file.issues?.length ?? 0),
182
+ 0
183
+ );
184
+ result.summary.totalIssues += issueCount;
185
+ } catch (err) {
186
+ console.error(`\u274C Error running tool '${provider.id}':`, err);
187
+ }
188
+ }
189
+ result.summary.config = sanitizeConfigRecursive({
190
+ scan: {
191
+ tools: requestedTools,
192
+ include: options.include,
193
+ exclude: options.exclude
194
+ },
195
+ // Use 'tools' for tool-specific configurations to match AIReadyConfig
196
+ tools: result.summary.toolConfigs
197
+ });
198
+ result.summary.executionTime = Date.now() - startTime;
199
+ return result;
200
+ }
201
+ async function scoreUnified(results, options) {
202
+ const toolScores = /* @__PURE__ */ new Map();
203
+ for (const toolId of results.summary.toolsRun) {
204
+ const provider = ToolRegistry.get(toolId);
205
+ if (!provider) continue;
206
+ const output = results[toolId];
207
+ if (!output) continue;
208
+ try {
209
+ const toolScore = provider.score(output, options);
210
+ if (!toolScore.tokenBudget) {
211
+ if (toolId === ToolName.PatternDetect && output.duplicates) {
212
+ const wastedTokens = output.duplicates.reduce(
213
+ (sum, d) => sum + (d.tokenCost ?? 0),
214
+ 0
215
+ );
216
+ toolScore.tokenBudget = calculateTokenBudget({
217
+ totalContextTokens: wastedTokens * 2,
218
+ wastedTokens: {
219
+ duplication: wastedTokens,
220
+ fragmentation: 0,
221
+ chattiness: 0
222
+ }
223
+ });
224
+ } else if (toolId === ToolName.ContextAnalyzer && output.summary) {
225
+ toolScore.tokenBudget = calculateTokenBudget({
226
+ totalContextTokens: output.summary.totalTokens,
227
+ wastedTokens: {
228
+ duplication: 0,
229
+ fragmentation: output.summary.totalPotentialSavings ?? 0,
230
+ chattiness: 0
231
+ }
232
+ });
233
+ }
234
+ }
235
+ toolScores.set(toolId, toolScore);
236
+ } catch (err) {
237
+ console.error(`\u274C Error scoring tool '${toolId}':`, err);
238
+ }
239
+ }
240
+ if (toolScores.size === 0) {
241
+ return {
242
+ overall: 0,
243
+ rating: "Critical",
244
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
245
+ toolsUsed: [],
246
+ breakdown: [],
247
+ calculation: {
248
+ formula: "0 / 0 = 0",
249
+ weights: {},
250
+ normalized: "0 / 0 = 0"
251
+ }
252
+ };
253
+ }
254
+ return calculateOverallScore(toolScores, options, void 0);
255
+ }
256
+ function generateUnifiedSummary(result) {
257
+ const { summary } = result;
258
+ let output = `\u{1F680} AIReady Analysis Complete
259
+
260
+ `;
261
+ output += `\u{1F4CA} Summary:
262
+ `;
263
+ output += ` Tools run: ${summary.toolsRun.join(", ")}
264
+ `;
265
+ output += ` Total issues found: ${summary.totalIssues}
266
+ `;
267
+ output += ` Execution time: ${(summary.executionTime / 1e3).toFixed(2)}s
268
+
269
+ `;
270
+ for (const provider of ToolRegistry.getAll()) {
271
+ const toolResult = result[provider.id];
272
+ if (toolResult) {
273
+ const issueCount = toolResult.results.reduce(
274
+ (sum, r) => sum + (r.issues?.length ?? 0),
275
+ 0
276
+ );
277
+ output += `\u2022 ${provider.id}: ${issueCount} issues
278
+ `;
279
+ }
280
+ }
281
+ return output;
282
+ }
283
+
284
+ export {
285
+ __require,
286
+ analyzeUnified,
287
+ scoreUnified,
288
+ generateUnifiedSummary
289
+ };