@zhixuan92/multi-model-agent-core 3.10.1 → 3.10.3
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 +1 -1
- package/dist/batch-registry.d.ts +15 -3
- package/dist/batch-registry.d.ts.map +1 -1
- package/dist/batch-registry.js +12 -5
- package/dist/batch-registry.js.map +1 -1
- package/dist/heartbeat.d.ts +15 -1
- package/dist/heartbeat.d.ts.map +1 -1
- package/dist/heartbeat.js +63 -1
- package/dist/heartbeat.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/observability/events.d.ts +2 -2
- package/dist/provider.d.ts +1 -0
- package/dist/provider.d.ts.map +1 -1
- package/dist/provider.js +12 -0
- package/dist/provider.js.map +1 -1
- package/dist/run-tasks/derive-terminal-status.d.ts +4 -0
- package/dist/run-tasks/derive-terminal-status.d.ts.map +1 -0
- package/dist/run-tasks/derive-terminal-status.js +25 -0
- package/dist/run-tasks/derive-terminal-status.js.map +1 -0
- package/dist/run-tasks/reviewed-lifecycle.d.ts +38 -0
- package/dist/run-tasks/reviewed-lifecycle.d.ts.map +1 -1
- package/dist/run-tasks/reviewed-lifecycle.js +112 -16
- package/dist/run-tasks/reviewed-lifecycle.js.map +1 -1
- package/dist/run-tasks/task-completion-summary.d.ts +23 -0
- package/dist/run-tasks/task-completion-summary.d.ts.map +1 -0
- package/dist/run-tasks/task-completion-summary.js +70 -0
- package/dist/run-tasks/task-completion-summary.js.map +1 -0
- package/dist/runners/types.d.ts +4 -0
- package/dist/runners/types.d.ts.map +1 -1
- package/dist/telemetry/clamp.d.ts +13 -0
- package/dist/telemetry/clamp.d.ts.map +1 -0
- package/dist/telemetry/clamp.js +13 -0
- package/dist/telemetry/clamp.js.map +1 -0
- package/dist/telemetry/event-builder.d.ts.map +1 -1
- package/dist/telemetry/event-builder.js +42 -43
- package/dist/telemetry/event-builder.js.map +1 -1
- package/dist/telemetry/field-coverage.d.ts +17 -0
- package/dist/telemetry/field-coverage.d.ts.map +1 -0
- package/dist/telemetry/field-coverage.js +100 -0
- package/dist/telemetry/field-coverage.js.map +1 -0
- package/dist/telemetry/types.d.ts +25 -25
- package/dist/telemetry/types.d.ts.map +1 -1
- package/dist/telemetry/types.js +15 -8
- package/dist/telemetry/types.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { deriveTerminalStatus } from './derive-terminal-status.js';
|
|
2
|
+
import { clampStageCost, clampTaskCost, clampInputTokens, clampOutputTokens, clampDurationMsTotal, } from '../telemetry/clamp.js';
|
|
3
|
+
// Derive each total INDEPENDENTLY from stage stats, mirroring event-builder
|
|
4
|
+
// exactly. Top-level totals must NEVER depend on runResult.usage — that field
|
|
5
|
+
// only carries the last implementer attempt and would lose reviewer + earlier
|
|
6
|
+
// rework cost (the same Gap 2 bug we already fixed in event-builder).
|
|
7
|
+
//
|
|
8
|
+
// Clamping is identical to event-builder via shared helpers from
|
|
9
|
+
// packages/core/src/telemetry/clamp.ts — guarantees the summary line and
|
|
10
|
+
// the V3 event never disagree on cost/token/duration values.
|
|
11
|
+
export function computeTaskCompletionSummary(args) {
|
|
12
|
+
const { runResult, taskIndexZero, totalTasks, batchId } = args;
|
|
13
|
+
const stageEntries = Object.values(runResult.stageStats ?? {}).filter((s) => s.entered);
|
|
14
|
+
// Sum across entered stages with per-stage clamping, then apply
|
|
15
|
+
// top-level clamping — exactly mirroring the two-level clamping in
|
|
16
|
+
// event-builder.ts (extractStageData + buildTaskCompletedEvent).
|
|
17
|
+
const sumFinite = (key, clampStage, clampTotal) => {
|
|
18
|
+
let total = 0;
|
|
19
|
+
let anyFinite = false;
|
|
20
|
+
for (const s of stageEntries) {
|
|
21
|
+
const v = s[key];
|
|
22
|
+
if (typeof v === 'number' && Number.isFinite(v)) {
|
|
23
|
+
total += clampStage(v);
|
|
24
|
+
anyFinite = true;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return anyFinite ? clampTotal(total) : null;
|
|
28
|
+
};
|
|
29
|
+
const totalDurationMs = clampDurationMsTotal(stageEntries.reduce((s, st) => {
|
|
30
|
+
const v = st['durationMs'];
|
|
31
|
+
return s + (typeof v === 'number' && Number.isFinite(v) ? v : 0);
|
|
32
|
+
}, 0));
|
|
33
|
+
return {
|
|
34
|
+
batchId,
|
|
35
|
+
taskIndexZero,
|
|
36
|
+
totalTasks,
|
|
37
|
+
terminalStatus: deriveTerminalStatus(runResult),
|
|
38
|
+
totalDurationMs,
|
|
39
|
+
totalCostUSD: sumFinite('costUSD', clampStageCost, clampTaskCost),
|
|
40
|
+
totalInputTokens: sumFinite('inputTokens', clampInputTokens, clampInputTokens),
|
|
41
|
+
totalOutputTokens: sumFinite('outputTokens', clampOutputTokens, clampOutputTokens),
|
|
42
|
+
turns: runResult.turns ?? 0,
|
|
43
|
+
filesWrittenCount: runResult.filesWritten?.length ?? 0,
|
|
44
|
+
specReviewVerdict: runResult.specReviewStatus ?? 'not_applicable',
|
|
45
|
+
qualityReviewVerdict: runResult.qualityReviewStatus ?? 'not_applicable',
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
export function formatTaskDoneLine(s) {
|
|
49
|
+
const idx = `task=${s.taskIndexZero + 1}/${s.totalTasks} taskIndex=${s.taskIndexZero}`;
|
|
50
|
+
const dur = formatDur(s.totalDurationMs);
|
|
51
|
+
const tokens = formatTokens(s.totalInputTokens, s.totalOutputTokens);
|
|
52
|
+
const cost = s.totalCostUSD === null ? '$unknown' : `$${s.totalCostUSD.toFixed(2)}`;
|
|
53
|
+
return `[mmagent] batch=${s.batchId.slice(0, 8)} ${idx} done: ${s.terminalStatus} in ${dur}, ${tokens}, ${cost}, ${s.turns} turns, ${s.filesWrittenCount} file(s) written, reviews [spec=${s.specReviewVerdict}, quality=${s.qualityReviewVerdict}]`;
|
|
54
|
+
}
|
|
55
|
+
function formatDur(ms) {
|
|
56
|
+
if (ms < 60_000)
|
|
57
|
+
return `${Math.round(ms / 1000)}s`;
|
|
58
|
+
const m = Math.floor(ms / 60_000);
|
|
59
|
+
const sec = Math.round((ms % 60_000) / 1000);
|
|
60
|
+
return `${m}m ${sec}s`;
|
|
61
|
+
}
|
|
62
|
+
function formatTokens(input, output) {
|
|
63
|
+
if (input === null && output === null)
|
|
64
|
+
return 'tokens=unknown';
|
|
65
|
+
const total = (input ?? 0) + (output ?? 0);
|
|
66
|
+
if (total < 1000)
|
|
67
|
+
return `${total} tokens`;
|
|
68
|
+
return `${Math.ceil(total / 1000)}k tokens`;
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=task-completion-summary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-completion-summary.js","sourceRoot":"","sources":["../../src/run-tasks/task-completion-summary.ts"],"names":[],"mappings":"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"}
|
package/dist/runners/types.d.ts
CHANGED
|
@@ -132,5 +132,9 @@ export type ProgressEvent = {
|
|
|
132
132
|
savedCostUSD: number | null;
|
|
133
133
|
final: boolean;
|
|
134
134
|
headline: string;
|
|
135
|
+
/** Per-stage idle time (ms since last LLM/tool/text event in the current stage). */
|
|
136
|
+
stageIdleMs: number;
|
|
137
|
+
/** Lightweight state snapshot for use by recordHeartbeat to update BatchRegistry. */
|
|
138
|
+
snapshot: import('../batch-registry.js').HeadlineSnapshot;
|
|
135
139
|
};
|
|
136
140
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runners/types.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runners/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare const clampStageCost: (n: number) => number;
|
|
2
|
+
export declare const clampTaskCost: (n: number) => number;
|
|
3
|
+
export declare const clampInputTokens: (n: number) => number;
|
|
4
|
+
export declare const clampOutputTokens: (n: number) => number;
|
|
5
|
+
export declare const clampCachedTokens: (n: number) => number;
|
|
6
|
+
export declare const clampReasoningTokens: (n: number) => number;
|
|
7
|
+
export declare const clampToolCallCount: (n: number) => number;
|
|
8
|
+
export declare const clampFilesReadCount: (n: number) => number;
|
|
9
|
+
export declare const clampFilesWrittenCount: (n: number) => number;
|
|
10
|
+
export declare const clampTurnCount: (n: number) => number;
|
|
11
|
+
export declare const clampDurationMsStage: (n: number) => number;
|
|
12
|
+
export declare const clampDurationMsTotal: (n: number) => number;
|
|
13
|
+
//# sourceMappingURL=clamp.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clamp.d.ts","sourceRoot":"","sources":["../../src/telemetry/clamp.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc,GAAI,GAAG,MAAM,KAAG,MACwB,CAAC;AAEpE,eAAO,MAAM,aAAa,GAAI,GAAG,MAAM,KAAG,MACX,CAAC;AAEhC,eAAO,MAAM,gBAAgB,GAAI,GAAG,MAAM,KAAG,MACR,CAAC;AAEtC,eAAO,MAAM,iBAAiB,GAAI,GAAG,MAAM,KAAG,MACX,CAAC;AAEpC,eAAO,MAAM,iBAAiB,GAAI,GAAG,MAAM,KAAG,MACT,CAAC;AAEtC,eAAO,MAAM,oBAAoB,GAAI,GAAG,MAAM,KAAG,MACd,CAAC;AAEpC,eAAO,MAAM,kBAAkB,GAAI,GAAG,MAAM,KAAG,MACf,CAAC;AAEjC,eAAO,MAAM,mBAAmB,GAAI,GAAG,MAAM,KAAG,MAChB,CAAC;AAEjC,eAAO,MAAM,sBAAsB,GAAI,GAAG,MAAM,KAAG,MACnB,CAAC;AAEjC,eAAO,MAAM,cAAc,GAAI,GAAG,MAAM,KAAG,MACZ,CAAC;AAEhC,eAAO,MAAM,oBAAoB,GAAI,GAAG,MAAM,KAAG,MACZ,CAAC;AAEtC,eAAO,MAAM,oBAAoB,GAAI,GAAG,MAAM,KAAG,MACX,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const clampStageCost = (n) => Math.max(0, Math.min(Math.round(n * 1_000_000) / 1_000_000, 100));
|
|
2
|
+
export const clampTaskCost = (n) => Math.max(0, Math.min(n, 800));
|
|
3
|
+
export const clampInputTokens = (n) => Math.min(Math.max(0, n), 5_000_000);
|
|
4
|
+
export const clampOutputTokens = (n) => Math.min(Math.max(0, n), 500_000);
|
|
5
|
+
export const clampCachedTokens = (n) => Math.min(Math.max(0, n), 5_000_000);
|
|
6
|
+
export const clampReasoningTokens = (n) => Math.min(Math.max(0, n), 500_000);
|
|
7
|
+
export const clampToolCallCount = (n) => Math.min(Math.max(0, n), 5000);
|
|
8
|
+
export const clampFilesReadCount = (n) => Math.min(Math.max(0, n), 5000);
|
|
9
|
+
export const clampFilesWrittenCount = (n) => Math.min(Math.max(0, n), 5000);
|
|
10
|
+
export const clampTurnCount = (n) => Math.min(Math.max(0, n), 250);
|
|
11
|
+
export const clampDurationMsStage = (n) => Math.min(Math.max(0, n), 3_600_000);
|
|
12
|
+
export const clampDurationMsTotal = (n) => Math.min(Math.max(0, n), 86_400_000);
|
|
13
|
+
//# sourceMappingURL=clamp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clamp.js","sourceRoot":"","sources":["../../src/telemetry/clamp.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,CAAS,EAAU,EAAE,CAClD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,SAAS,CAAC,GAAG,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC;AAEpE,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,CAAS,EAAU,EAAE,CACjD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAEhC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAS,EAAU,EAAE,CACpD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;AAEtC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAS,EAAU,EAAE,CACrD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAEpC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAS,EAAU,EAAE,CACrD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;AAEtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAS,EAAU,EAAE,CACxD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAEpC,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAS,EAAU,EAAE,CACtD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AAEjC,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,CAAS,EAAU,EAAE,CACvD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AAEjC,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAS,EAAU,EAAE,CAC1D,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AAEjC,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,CAAS,EAAU,EAAE,CAClD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAEhC,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAS,EAAU,EAAE,CACxD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;AAEtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAS,EAAU,EAAE,CACxD,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-builder.d.ts","sourceRoot":"","sources":["../../src/telemetry/event-builder.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAiB,MAAM,aAAa,CAAC;AAI5D,OAAO,KAAK,EAAE,sBAAsB,EAAuC,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"event-builder.d.ts","sourceRoot":"","sources":["../../src/telemetry/event-builder.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAiB,MAAM,aAAa,CAAC;AAI5D,OAAO,KAAK,EAAE,sBAAsB,EAAuC,MAAM,YAAY,CAAC;AAmB9F,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,UAAU,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,GAAG,cAAc,GAAG,OAAO,GAAG,aAAa,CAAC;IACvG,QAAQ,EAAE;QAAE,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC;IACnC,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,GAAG,cAAc,GAAG,WAAW,GAAG,MAAM,CAAC;IAC9D,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAMD,wBAAgB,uBAAuB,CAAC,GAAG,EAAE,YAAY,GAAG,sBAAsB,CA0EjF"}
|
|
@@ -2,6 +2,8 @@ import { randomUUID } from 'node:crypto';
|
|
|
2
2
|
import { computeSavedCostUSD } from '../types.js';
|
|
3
3
|
import { normalizeModel } from './normalize.js';
|
|
4
4
|
import { classifyConcern } from './concern-classifier.js';
|
|
5
|
+
import { deriveTerminalStatus } from '../run-tasks/derive-terminal-status.js';
|
|
6
|
+
import { clampStageCost, clampTaskCost, clampInputTokens, clampOutputTokens, clampCachedTokens, clampReasoningTokens, clampToolCallCount, clampFilesReadCount, clampFilesWrittenCount, clampTurnCount, clampDurationMsStage, clampDurationMsTotal, } from './clamp.js';
|
|
5
7
|
const KNOWN_CAPABILITIES = new Set(['web_search', 'web_fetch']);
|
|
6
8
|
const REVIEWED_ROUTES = new Set(['delegate', 'audit', 'review', 'verify', 'debug', 'execute-plan', 'investigate']);
|
|
7
9
|
const QUALITY_ONLY_ROUTES = new Set(['audit', 'review', 'verify', 'debug', 'investigate']);
|
|
@@ -9,8 +11,24 @@ const VERIFY_ROUTES = new Set(['delegate', 'execute-plan', 'verify']);
|
|
|
9
11
|
export function buildTaskCompletedEvent(ctx) {
|
|
10
12
|
const { route, runResult, client, parentModel } = ctx;
|
|
11
13
|
const stages = buildStages(route, runResult);
|
|
12
|
-
|
|
13
|
-
|
|
14
|
+
// R4 invariant: totalDurationMs MUST be >= Σ stage.durationMs. runResult.durationMs and per-stage
|
|
15
|
+
// durations are sampled at different `Date.now()` ticks, so a per-stage measurement can land 1ms
|
|
16
|
+
// longer than the task-level total. Take the max of (runResult.durationMs, stage-sum) to enforce
|
|
17
|
+
// R4 by construction; without this guarantee, every event with millisecond-precision drift gets
|
|
18
|
+
// dropped by the V3 emit-time validator.
|
|
19
|
+
const stageDurationsSum = stages.reduce((s, st) => s + st.durationMs, 0);
|
|
20
|
+
const totalDurationMs = clampDurationMsTotal(Math.max(runResult.durationMs ?? 0, stageDurationsSum));
|
|
21
|
+
// Top-level totals are summed across all stages (impl + reviewers + reworks +
|
|
22
|
+
// verify + commit) so the dashboard's `total_cost_cents` reflects the true
|
|
23
|
+
// task cost. runResult.usage only carries the LAST implementer attempt and
|
|
24
|
+
// ignores reviewer + earlier-impl rounds — using it would systematically
|
|
25
|
+
// under-report cost (~24× in real-world rework cases).
|
|
26
|
+
const totalCostUSD = clampTaskCost(stages.reduce((s, st) => s + (st.costUSD ?? 0), 0));
|
|
27
|
+
const totalInputTokens = clampInputTokens(stages.reduce((s, st) => s + (st.inputTokens ?? 0), 0));
|
|
28
|
+
const totalOutputTokens = clampOutputTokens(stages.reduce((s, st) => s + (st.outputTokens ?? 0), 0));
|
|
29
|
+
const totalCachedTokens = clampCachedTokens(stages.reduce((s, st) => s + (st.cachedTokens ?? 0), 0));
|
|
30
|
+
const totalReasoningTokens = clampReasoningTokens(stages.reduce((s, st) => s + (st.reasoningTokens ?? 0), 0));
|
|
31
|
+
const savedCostUSD = computeSavedCostUSD(totalCostUSD, totalInputTokens, totalOutputTokens, parentModel ?? undefined);
|
|
14
32
|
const reviewPolicy = ctx.reviewPolicy ?? (QUALITY_ONLY_ROUTES.has(route) ? 'quality_only' : 'full');
|
|
15
33
|
const verifyCommandPresent = ctx.verifyCommandPresent ?? false;
|
|
16
34
|
const implModelRaw = runResult.models?.implementer ?? null;
|
|
@@ -34,12 +52,12 @@ export function buildTaskCompletedEvent(ctx) {
|
|
|
34
52
|
workerStatus: deriveWorkerStatus(runResult),
|
|
35
53
|
errorCode: deriveErrorCode(runResult),
|
|
36
54
|
parentModelFamily: parentModel ? normalizeModel(parentModel).family : 'other',
|
|
37
|
-
inputTokens:
|
|
38
|
-
outputTokens:
|
|
39
|
-
cachedTokens:
|
|
40
|
-
reasoningTokens:
|
|
55
|
+
inputTokens: totalInputTokens,
|
|
56
|
+
outputTokens: totalOutputTokens,
|
|
57
|
+
cachedTokens: totalCachedTokens,
|
|
58
|
+
reasoningTokens: totalReasoningTokens,
|
|
41
59
|
totalDurationMs,
|
|
42
|
-
totalCostUSD
|
|
60
|
+
totalCostUSD,
|
|
43
61
|
totalSavedCostUSD: savedCostUSD,
|
|
44
62
|
concernCount: Math.min(runResult.concerns?.length ?? 0, 150),
|
|
45
63
|
escalationCount,
|
|
@@ -106,16 +124,16 @@ function extractStageData(raw, _rr, _stageName) {
|
|
|
106
124
|
return {
|
|
107
125
|
model: raw.model ? normalizeModel(raw.model).canonical : 'custom',
|
|
108
126
|
agentTier: (raw.agentTier === 'complex' ? 'reasoning' : 'standard'),
|
|
109
|
-
durationMs:
|
|
110
|
-
costUSD:
|
|
111
|
-
inputTokens: raw.inputTokens ?? 0,
|
|
112
|
-
outputTokens: raw.outputTokens ?? 0,
|
|
113
|
-
cachedTokens: raw.cachedTokens ?? 0,
|
|
114
|
-
reasoningTokens: raw.reasoningTokens ?? 0,
|
|
115
|
-
toolCallCount: raw.toolCallCount ?? 0,
|
|
116
|
-
filesReadCount: raw.filesReadCount ?? 0,
|
|
117
|
-
filesWrittenCount: raw.filesWrittenCount ?? 0,
|
|
118
|
-
turnCount: raw.turnCount ?? 0,
|
|
127
|
+
durationMs: clampDurationMsStage(raw.durationMs ?? 0),
|
|
128
|
+
costUSD: clampStageCost(raw.costUSD ?? 0),
|
|
129
|
+
inputTokens: clampInputTokens(raw.inputTokens ?? 0),
|
|
130
|
+
outputTokens: clampOutputTokens(raw.outputTokens ?? 0),
|
|
131
|
+
cachedTokens: clampCachedTokens(raw.cachedTokens ?? 0),
|
|
132
|
+
reasoningTokens: clampReasoningTokens(raw.reasoningTokens ?? 0),
|
|
133
|
+
toolCallCount: clampToolCallCount(raw.toolCallCount ?? 0),
|
|
134
|
+
filesReadCount: clampFilesReadCount(raw.filesReadCount ?? 0),
|
|
135
|
+
filesWrittenCount: clampFilesWrittenCount(raw.filesWrittenCount ?? 0),
|
|
136
|
+
turnCount: clampTurnCount(raw.turnCount ?? 0),
|
|
119
137
|
maxIdleMs: raw.maxIdleMs ?? null,
|
|
120
138
|
totalIdleMs: raw.totalIdleMs ?? null,
|
|
121
139
|
};
|
|
@@ -187,38 +205,19 @@ function buildCommitStage(rr) {
|
|
|
187
205
|
const base = extractStageData(ss, rr, 'committing');
|
|
188
206
|
if (!base)
|
|
189
207
|
return null;
|
|
208
|
+
const commits = Array.isArray(rr.commits) ? rr.commits : [];
|
|
209
|
+
const allFiles = commits.flatMap((c) => Array.isArray(c?.filesChanged)
|
|
210
|
+
? c.filesChanged.filter((f) => typeof f === 'string')
|
|
211
|
+
: []);
|
|
212
|
+
const filesCommittedCount = Math.min(new Set(allFiles).size, 1000);
|
|
190
213
|
return {
|
|
191
214
|
name: 'committing',
|
|
192
215
|
...base,
|
|
193
|
-
filesCommittedCount
|
|
194
|
-
branchCreated: false,
|
|
216
|
+
filesCommittedCount,
|
|
217
|
+
branchCreated: false, // TODO(3.10.3): wire branch-creation tracking — name-diff is unreliable
|
|
195
218
|
};
|
|
196
219
|
}
|
|
197
220
|
// ── Derivation helpers ─────────────────────────────────────────────────────
|
|
198
|
-
function deriveTerminalStatus(rr) {
|
|
199
|
-
const tr = rr.terminationReason;
|
|
200
|
-
if (tr === 'all_tiers_unavailable')
|
|
201
|
-
return 'unavailable';
|
|
202
|
-
if (tr === 'cost_ceiling')
|
|
203
|
-
return 'cost_exceeded';
|
|
204
|
-
if (tr === 'round_cap')
|
|
205
|
-
return 'incomplete';
|
|
206
|
-
if (!tr || typeof tr !== 'object')
|
|
207
|
-
return 'incomplete';
|
|
208
|
-
switch (tr.cause) {
|
|
209
|
-
case 'finished': return 'ok';
|
|
210
|
-
case 'incomplete':
|
|
211
|
-
case 'degenerate_exhausted': return 'incomplete';
|
|
212
|
-
case 'timeout': return 'timeout';
|
|
213
|
-
case 'cost_exceeded': return 'cost_exceeded';
|
|
214
|
-
case 'brief_too_vague': return 'brief_too_vague';
|
|
215
|
-
case 'api_error':
|
|
216
|
-
case 'network_error':
|
|
217
|
-
case 'api_aborted':
|
|
218
|
-
case 'error': return 'error';
|
|
219
|
-
default: return 'incomplete';
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
221
|
function deriveErrorCode(rr) {
|
|
223
222
|
if (rr.structuredError?.code)
|
|
224
223
|
return rr.structuredError.code;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-builder.js","sourceRoot":"","sources":["../../src/telemetry/event-builder.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"event-builder.js","sourceRoot":"","sources":["../../src/telemetry/event-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export type FieldCoverage = {
|
|
2
|
+
kind: 'derived';
|
|
3
|
+
source: string;
|
|
4
|
+
} | {
|
|
5
|
+
kind: 'constant';
|
|
6
|
+
reason: string;
|
|
7
|
+
} | {
|
|
8
|
+
kind: 'unavailable';
|
|
9
|
+
targetVersion: string;
|
|
10
|
+
reason: string;
|
|
11
|
+
} | {
|
|
12
|
+
kind: 'not_applicable';
|
|
13
|
+
reason: string;
|
|
14
|
+
};
|
|
15
|
+
export declare const TASK_COMPLETED_FIELD_COVERAGE: Record<string, FieldCoverage>;
|
|
16
|
+
export declare const STAGE_FIELD_COVERAGE: Record<string, Record<string, FieldCoverage>>;
|
|
17
|
+
//# sourceMappingURL=field-coverage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"field-coverage.d.ts","sourceRoot":"","sources":["../../src/telemetry/field-coverage.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GACrB;IAAE,IAAI,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACnC;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GACpC;IAAE,IAAI,EAAE,aAAa,CAAC;IAAC,aAAa,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,GAC9D;IAAE,IAAI,EAAE,gBAAgB,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAE/C,eAAO,MAAM,6BAA6B,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CA8BvE,CAAC;AAmBF,eAAO,MAAM,oBAAoB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAmD9E,CAAC"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
export const TASK_COMPLETED_FIELD_COVERAGE = {
|
|
2
|
+
eventId: { kind: 'derived', source: 'randomUUID() per build' },
|
|
3
|
+
route: { kind: 'derived', source: 'BuildContext.route' },
|
|
4
|
+
client: { kind: 'derived', source: 'BuildContext.client' },
|
|
5
|
+
agentType: { kind: 'derived', source: 'runResult.agents.implementer' },
|
|
6
|
+
toolMode: { kind: 'derived', source: 'runResult.agents.implementerToolMode' },
|
|
7
|
+
capabilities: { kind: 'derived', source: 'runResult.agents.implementerCapabilities' },
|
|
8
|
+
reviewPolicy: { kind: 'derived', source: 'BuildContext.reviewPolicy or route default' },
|
|
9
|
+
verifyCommandPresent: { kind: 'derived', source: 'BuildContext.verifyCommandPresent' },
|
|
10
|
+
implementerModel: { kind: 'derived', source: 'runResult.models.implementer (normalized)' },
|
|
11
|
+
terminalStatus: { kind: 'derived', source: 'runResult.terminationReason' },
|
|
12
|
+
workerStatus: { kind: 'derived', source: 'runResult.workerStatus' },
|
|
13
|
+
errorCode: { kind: 'derived', source: 'runResult.error / status' },
|
|
14
|
+
parentModelFamily: { kind: 'derived', source: 'BuildContext.parentModel (normalized)' },
|
|
15
|
+
inputTokens: { kind: 'derived', source: 'sum(stages[].inputTokens)' },
|
|
16
|
+
outputTokens: { kind: 'derived', source: 'sum(stages[].outputTokens)' },
|
|
17
|
+
cachedTokens: { kind: 'derived', source: 'sum(stages[].cachedTokens)' },
|
|
18
|
+
reasoningTokens: { kind: 'derived', source: 'sum(stages[].reasoningTokens)' },
|
|
19
|
+
totalDurationMs: { kind: 'derived', source: 'runResult.durationMs ?? sum(stages[].durationMs)' },
|
|
20
|
+
totalCostUSD: { kind: 'derived', source: 'sum(stages[].costUSD)' },
|
|
21
|
+
totalSavedCostUSD: { kind: 'derived', source: 'computeSavedCostUSD(totals, parentModel)' },
|
|
22
|
+
concernCount: { kind: 'derived', source: 'min(runResult.concerns.length, 150)' },
|
|
23
|
+
escalationCount: { kind: 'derived', source: 'distinctProviders(escalationLog) - 1, capped at 20' },
|
|
24
|
+
fallbackCount: { kind: 'derived', source: 'min(runResult.agents.fallbackOverrides.length, 20)' },
|
|
25
|
+
stallCount: { kind: 'derived', source: 'runResult.stallCount or stallTriggered' },
|
|
26
|
+
taskMaxIdleMs: { kind: 'derived', source: 'runResult.taskMaxIdleMs' },
|
|
27
|
+
clarificationRequested: { kind: 'derived', source: 'runResult.lifecycleClarificationRequested' },
|
|
28
|
+
briefQualityWarningCount: { kind: 'derived', source: 'min(runResult.briefQualityWarnings.length, 20)' },
|
|
29
|
+
sandboxViolationCount: { kind: 'derived', source: 'min(runResult.sandboxViolationCount, 100)' },
|
|
30
|
+
stages: { kind: 'derived', source: 'buildStages(route, runResult)' },
|
|
31
|
+
};
|
|
32
|
+
const COMMON_STAGE_COVERAGE = {
|
|
33
|
+
model: { kind: 'derived', source: 'stageStats[name].model' },
|
|
34
|
+
agentTier: { kind: 'derived', source: 'stageStats[name].agentTier' },
|
|
35
|
+
durationMs: { kind: 'derived', source: 'stageStats[name].durationMs' },
|
|
36
|
+
costUSD: { kind: 'derived', source: 'stageStats[name].costUSD' },
|
|
37
|
+
inputTokens: { kind: 'derived', source: 'stageStats[name].inputTokens' },
|
|
38
|
+
outputTokens: { kind: 'derived', source: 'stageStats[name].outputTokens' },
|
|
39
|
+
cachedTokens: { kind: 'derived', source: 'stageStats[name].cachedTokens' },
|
|
40
|
+
reasoningTokens: { kind: 'derived', source: 'stageStats[name].reasoningTokens' },
|
|
41
|
+
toolCallCount: { kind: 'derived', source: 'stageStats[name].toolCallCount' },
|
|
42
|
+
filesReadCount: { kind: 'derived', source: 'stageStats[name].filesReadCount' },
|
|
43
|
+
filesWrittenCount: { kind: 'derived', source: 'stageStats[name].filesWrittenCount' },
|
|
44
|
+
turnCount: { kind: 'derived', source: 'stageStats[name].turnCount' },
|
|
45
|
+
maxIdleMs: { kind: 'derived', source: 'stageStats[name].maxIdleMs' },
|
|
46
|
+
totalIdleMs: { kind: 'derived', source: 'stageStats[name].totalIdleMs' },
|
|
47
|
+
};
|
|
48
|
+
export const STAGE_FIELD_COVERAGE = {
|
|
49
|
+
implementing: { ...COMMON_STAGE_COVERAGE },
|
|
50
|
+
spec_review: {
|
|
51
|
+
...COMMON_STAGE_COVERAGE,
|
|
52
|
+
verdict: { kind: 'derived', source: 'specReviewStatus' },
|
|
53
|
+
roundsUsed: { kind: 'derived', source: 'reviewRounds.spec' },
|
|
54
|
+
concernCategories: { kind: 'derived', source: 'concerns.filter(spec_review).map(classifyConcern)' },
|
|
55
|
+
findingsBySeverity: { kind: 'derived', source: 'concerns.filter(spec_review).groupBy(severity)' },
|
|
56
|
+
},
|
|
57
|
+
quality_review: {
|
|
58
|
+
...COMMON_STAGE_COVERAGE,
|
|
59
|
+
verdict: { kind: 'derived', source: 'qualityReviewStatus' },
|
|
60
|
+
roundsUsed: { kind: 'derived', source: 'reviewRounds.quality' },
|
|
61
|
+
concernCategories: { kind: 'derived', source: 'concerns.filter(quality_review).map(classifyConcern)' },
|
|
62
|
+
findingsBySeverity: { kind: 'derived', source: 'concerns.filter(quality_review).groupBy(severity)' },
|
|
63
|
+
},
|
|
64
|
+
diff_review: {
|
|
65
|
+
...COMMON_STAGE_COVERAGE,
|
|
66
|
+
verdict: { kind: 'derived', source: 'diffReviewStatus' },
|
|
67
|
+
roundsUsed: { kind: 'constant', reason: 'diff_review never reworks; always 1 when entered' },
|
|
68
|
+
concernCategories: { kind: 'derived', source: 'concerns.filter(diff_review).map(classifyConcern)' },
|
|
69
|
+
findingsBySeverity: { kind: 'derived', source: 'concerns.filter(diff_review).groupBy(severity)' },
|
|
70
|
+
},
|
|
71
|
+
spec_rework: {
|
|
72
|
+
...COMMON_STAGE_COVERAGE,
|
|
73
|
+
triggeringConcernCategories: { kind: 'derived', source: 'concerns.filter(spec_review).map(classifyConcern)' },
|
|
74
|
+
},
|
|
75
|
+
quality_rework: {
|
|
76
|
+
...COMMON_STAGE_COVERAGE,
|
|
77
|
+
triggeringConcernCategories: { kind: 'derived', source: 'concerns.filter(quality_review).map(classifyConcern)' },
|
|
78
|
+
},
|
|
79
|
+
verifying: {
|
|
80
|
+
...COMMON_STAGE_COVERAGE,
|
|
81
|
+
inputTokens: { kind: 'constant', reason: 'verify runs shell commands, not LLM — no tokens' },
|
|
82
|
+
outputTokens: { kind: 'constant', reason: 'verify runs shell commands, not LLM — no tokens' },
|
|
83
|
+
cachedTokens: { kind: 'constant', reason: 'verify runs shell commands, not LLM — no tokens' },
|
|
84
|
+
reasoningTokens: { kind: 'constant', reason: 'verify runs shell commands, not LLM — no tokens' },
|
|
85
|
+
turnCount: { kind: 'constant', reason: 'verify runs shell commands, not LLM — no turns' },
|
|
86
|
+
outcome: { kind: 'derived', source: 'verifyStageResult.status' },
|
|
87
|
+
skipReason: { kind: 'derived', source: 'verifyStageResult.skipReason' },
|
|
88
|
+
},
|
|
89
|
+
committing: {
|
|
90
|
+
...COMMON_STAGE_COVERAGE,
|
|
91
|
+
inputTokens: { kind: 'constant', reason: 'commit stage runs git commands, not LLM — no tokens' },
|
|
92
|
+
outputTokens: { kind: 'constant', reason: 'commit stage runs git commands, not LLM — no tokens' },
|
|
93
|
+
cachedTokens: { kind: 'constant', reason: 'commit stage runs git commands, not LLM — no tokens' },
|
|
94
|
+
reasoningTokens: { kind: 'constant', reason: 'commit stage runs git commands, not LLM — no tokens' },
|
|
95
|
+
turnCount: { kind: 'constant', reason: 'commit stage runs git commands, not LLM — no turns' },
|
|
96
|
+
filesCommittedCount: { kind: 'derived', source: 'commitResult.filesCommittedCount' },
|
|
97
|
+
branchCreated: { kind: 'derived', source: 'commitResult.branchCreated' },
|
|
98
|
+
},
|
|
99
|
+
};
|
|
100
|
+
//# sourceMappingURL=field-coverage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"field-coverage.js","sourceRoot":"","sources":["../../src/telemetry/field-coverage.ts"],"names":[],"mappings":"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"}
|