@shapeshift-labs/frontier-swarm 0.5.9 → 0.5.11
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 +62 -3
- package/benchmarks/package-bench-fixtures.mjs +95 -0
- package/benchmarks/package-bench-rows.mjs +190 -0
- package/benchmarks/package-bench-runtime.mjs +94 -0
- package/benchmarks/package-bench.mjs +20 -307
- package/dist/adaptive-load-decisions.d.ts +6 -0
- package/dist/adaptive-load-decisions.d.ts.map +1 -0
- package/dist/adaptive-load-decisions.js +130 -0
- package/dist/adaptive-load-decisions.js.map +1 -0
- package/dist/adaptive-load-limits.d.ts +8 -0
- package/dist/adaptive-load-limits.d.ts.map +1 -0
- package/dist/adaptive-load-limits.js +105 -0
- package/dist/adaptive-load-limits.js.map +1 -0
- package/dist/adaptive-load-observations.d.ts +16 -0
- package/dist/adaptive-load-observations.d.ts.map +1 -0
- package/dist/adaptive-load-observations.js +248 -0
- package/dist/adaptive-load-observations.js.map +1 -0
- package/dist/adaptive-load-types.d.ts +108 -0
- package/dist/adaptive-load-types.d.ts.map +1 -0
- package/dist/adaptive-load-types.js +3 -0
- package/dist/adaptive-load-types.js.map +1 -0
- package/dist/adaptive-load.d.ts +10 -0
- package/dist/adaptive-load.d.ts.map +1 -0
- package/dist/adaptive-load.js +87 -0
- package/dist/adaptive-load.js.map +1 -0
- package/dist/adaptive-types.d.ts +118 -0
- package/dist/adaptive-types.d.ts.map +1 -0
- package/dist/adaptive-types.js +2 -0
- package/dist/adaptive-types.js.map +1 -0
- package/dist/artifact-routing-runtime.d.ts +3 -0
- package/dist/artifact-routing-runtime.d.ts.map +1 -0
- package/dist/artifact-routing-runtime.js +72 -0
- package/dist/artifact-routing-runtime.js.map +1 -0
- package/dist/auto-review.d.ts +47 -0
- package/dist/auto-review.d.ts.map +1 -0
- package/dist/auto-review.js +69 -0
- package/dist/auto-review.js.map +1 -0
- package/dist/blackboard.d.ts +81 -0
- package/dist/blackboard.d.ts.map +1 -0
- package/dist/blackboard.js +60 -0
- package/dist/blackboard.js.map +1 -0
- package/dist/coercion.d.ts +12 -0
- package/dist/coercion.d.ts.map +1 -0
- package/dist/coercion.js +48 -0
- package/dist/coercion.js.map +1 -0
- package/dist/constants.d.ts +94 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +94 -0
- package/dist/constants.js.map +1 -0
- package/dist/context-pack-runtime.d.ts +3 -0
- package/dist/context-pack-runtime.d.ts.map +1 -0
- package/dist/context-pack-runtime.js +77 -0
- package/dist/context-pack-runtime.js.map +1 -0
- package/dist/context-types.d.ts +188 -0
- package/dist/context-types.d.ts.map +1 -0
- package/dist/context-types.js +2 -0
- package/dist/context-types.js.map +1 -0
- package/dist/coordinator-dashboard-helpers.d.ts +14 -0
- package/dist/coordinator-dashboard-helpers.d.ts.map +1 -0
- package/dist/coordinator-dashboard-helpers.js +106 -0
- package/dist/coordinator-dashboard-helpers.js.map +1 -0
- package/dist/coordinator-dashboard-types.d.ts +161 -0
- package/dist/coordinator-dashboard-types.d.ts.map +1 -0
- package/dist/coordinator-dashboard-types.js +3 -0
- package/dist/coordinator-dashboard-types.js.map +1 -0
- package/dist/coordinator-dashboard.d.ts +4 -0
- package/dist/coordinator-dashboard.d.ts.map +1 -0
- package/dist/coordinator-dashboard.js +161 -0
- package/dist/coordinator-dashboard.js.map +1 -0
- package/dist/coordinator-scoring.d.ts +8 -0
- package/dist/coordinator-scoring.d.ts.map +1 -0
- package/dist/coordinator-scoring.js +134 -0
- package/dist/coordinator-scoring.js.map +1 -0
- package/dist/coordinator-types.d.ts +164 -0
- package/dist/coordinator-types.d.ts.map +1 -0
- package/dist/coordinator-types.js +2 -0
- package/dist/coordinator-types.js.map +1 -0
- package/dist/debug-runtime.d.ts +4 -0
- package/dist/debug-runtime.d.ts.map +1 -0
- package/dist/debug-runtime.js +93 -0
- package/dist/debug-runtime.js.map +1 -0
- package/dist/debug-types.d.ts +194 -0
- package/dist/debug-types.d.ts.map +1 -0
- package/dist/debug-types.js +2 -0
- package/dist/debug-types.js.map +1 -0
- package/dist/diagnostic-helpers.d.ts +5 -0
- package/dist/diagnostic-helpers.d.ts.map +1 -0
- package/dist/diagnostic-helpers.js +54 -0
- package/dist/diagnostic-helpers.js.map +1 -0
- package/dist/evidence-index-helpers.d.ts +10 -0
- package/dist/evidence-index-helpers.d.ts.map +1 -0
- package/dist/evidence-index-helpers.js +78 -0
- package/dist/evidence-index-helpers.js.map +1 -0
- package/dist/evidence-index.d.ts +4 -0
- package/dist/evidence-index.d.ts.map +1 -0
- package/dist/evidence-index.js +59 -0
- package/dist/evidence-index.js.map +1 -0
- package/dist/evidence-types.d.ts +151 -0
- package/dist/evidence-types.d.ts.map +1 -0
- package/dist/evidence-types.js +2 -0
- package/dist/evidence-types.js.map +1 -0
- package/dist/fixtures.d.ts +45 -0
- package/dist/fixtures.d.ts.map +1 -0
- package/dist/fixtures.js +39 -0
- package/dist/fixtures.js.map +1 -0
- package/dist/governance-types.d.ts +172 -0
- package/dist/governance-types.d.ts.map +1 -0
- package/dist/governance-types.js +2 -0
- package/dist/governance-types.js.map +1 -0
- package/dist/index.d.ts +35 -2933
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +34 -4526
- package/dist/index.js.map +1 -1
- package/dist/instrumentation-runtime.d.ts +6 -0
- package/dist/instrumentation-runtime.d.ts.map +1 -0
- package/dist/instrumentation-runtime.js +111 -0
- package/dist/instrumentation-runtime.js.map +1 -0
- package/dist/internal.d.ts +11 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +49 -0
- package/dist/internal.js.map +1 -0
- package/dist/leases.d.ts +32 -0
- package/dist/leases.d.ts.map +1 -0
- package/dist/leases.js +36 -0
- package/dist/leases.js.map +1 -0
- package/dist/manifest-normalization.d.ts +8 -0
- package/dist/manifest-normalization.d.ts.map +1 -0
- package/dist/manifest-normalization.js +191 -0
- package/dist/manifest-normalization.js.map +1 -0
- package/dist/manifest-types.d.ts +227 -0
- package/dist/manifest-types.d.ts.map +1 -0
- package/dist/manifest-types.js +2 -0
- package/dist/manifest-types.js.map +1 -0
- package/dist/manifest.d.ts +7 -0
- package/dist/manifest.d.ts.map +1 -0
- package/dist/manifest.js +126 -0
- package/dist/manifest.js.map +1 -0
- package/dist/merge-admission.d.ts +3 -0
- package/dist/merge-admission.d.ts.map +1 -0
- package/dist/merge-admission.js +71 -0
- package/dist/merge-admission.js.map +1 -0
- package/dist/merge-bundles.d.ts +13 -0
- package/dist/merge-bundles.d.ts.map +1 -0
- package/dist/merge-bundles.js +144 -0
- package/dist/merge-bundles.js.map +1 -0
- package/dist/merge-classification.d.ts +6 -0
- package/dist/merge-classification.d.ts.map +1 -0
- package/dist/merge-classification.js +36 -0
- package/dist/merge-classification.js.map +1 -0
- package/dist/merge-index.d.ts +3 -0
- package/dist/merge-index.d.ts.map +1 -0
- package/dist/merge-index.js +130 -0
- package/dist/merge-index.js.map +1 -0
- package/dist/merge-plan-helpers.d.ts +11 -0
- package/dist/merge-plan-helpers.d.ts.map +1 -0
- package/dist/merge-plan-helpers.js +97 -0
- package/dist/merge-plan-helpers.js.map +1 -0
- package/dist/merge-plans-runtime.d.ts +8 -0
- package/dist/merge-plans-runtime.d.ts.map +1 -0
- package/dist/merge-plans-runtime.js +106 -0
- package/dist/merge-plans-runtime.js.map +1 -0
- package/dist/merge-review-types.d.ts +76 -0
- package/dist/merge-review-types.d.ts.map +1 -0
- package/dist/merge-review-types.js +2 -0
- package/dist/merge-review-types.js.map +1 -0
- package/dist/merge-review.d.ts +7 -0
- package/dist/merge-review.d.ts.map +1 -0
- package/dist/merge-review.js +142 -0
- package/dist/merge-review.js.map +1 -0
- package/dist/merge-types.d.ts +196 -0
- package/dist/merge-types.d.ts.map +1 -0
- package/dist/merge-types.js +2 -0
- package/dist/merge-types.js.map +1 -0
- package/dist/merge-wrappers.d.ts +5 -0
- package/dist/merge-wrappers.d.ts.map +1 -0
- package/dist/merge-wrappers.js +198 -0
- package/dist/merge-wrappers.js.map +1 -0
- package/dist/observability-types.d.ts +164 -0
- package/dist/observability-types.d.ts.map +1 -0
- package/dist/observability-types.js +2 -0
- package/dist/observability-types.js.map +1 -0
- package/dist/oracle-helpers.d.ts +6 -0
- package/dist/oracle-helpers.d.ts.map +1 -0
- package/dist/oracle-helpers.js +73 -0
- package/dist/oracle-helpers.js.map +1 -0
- package/dist/oracle-runtime.d.ts +5 -0
- package/dist/oracle-runtime.d.ts.map +1 -0
- package/dist/oracle-runtime.js +154 -0
- package/dist/oracle-runtime.js.map +1 -0
- package/dist/ownership-runtime.d.ts +6 -0
- package/dist/ownership-runtime.d.ts.map +1 -0
- package/dist/ownership-runtime.js +49 -0
- package/dist/ownership-runtime.js.map +1 -0
- package/dist/patch-stack-runtime.d.ts +4 -0
- package/dist/patch-stack-runtime.d.ts.map +1 -0
- package/dist/patch-stack-runtime.js +97 -0
- package/dist/patch-stack-runtime.js.map +1 -0
- package/dist/plan-helpers.d.ts +13 -0
- package/dist/plan-helpers.d.ts.map +1 -0
- package/dist/plan-helpers.js +236 -0
- package/dist/plan-helpers.js.map +1 -0
- package/dist/plan-selection.d.ts +7 -0
- package/dist/plan-selection.d.ts.map +1 -0
- package/dist/plan-selection.js +86 -0
- package/dist/plan-selection.js.map +1 -0
- package/dist/plan.d.ts +126 -0
- package/dist/plan.d.ts.map +1 -0
- package/dist/plan.js +67 -0
- package/dist/plan.js.map +1 -0
- package/dist/progress.d.ts +42 -0
- package/dist/progress.d.ts.map +1 -0
- package/dist/progress.js +31 -0
- package/dist/progress.js.map +1 -0
- package/dist/proof-runtime.d.ts +16 -0
- package/dist/proof-runtime.d.ts.map +1 -0
- package/dist/proof-runtime.js +143 -0
- package/dist/proof-runtime.js.map +1 -0
- package/dist/queue-overlays.d.ts +7 -0
- package/dist/queue-overlays.d.ts.map +1 -0
- package/dist/queue-overlays.js +184 -0
- package/dist/queue-overlays.js.map +1 -0
- package/dist/queue-types.d.ts +194 -0
- package/dist/queue-types.d.ts.map +1 -0
- package/dist/queue-types.js +2 -0
- package/dist/queue-types.js.map +1 -0
- package/dist/rebase-report.d.ts +3 -0
- package/dist/rebase-report.d.ts.map +1 -0
- package/dist/rebase-report.js +52 -0
- package/dist/rebase-report.js.map +1 -0
- package/dist/record-helpers.d.ts +15 -0
- package/dist/record-helpers.d.ts.map +1 -0
- package/dist/record-helpers.js +78 -0
- package/dist/record-helpers.js.map +1 -0
- package/dist/reference-oracle-runtime.d.ts +4 -0
- package/dist/reference-oracle-runtime.d.ts.map +1 -0
- package/dist/reference-oracle-runtime.js +89 -0
- package/dist/reference-oracle-runtime.js.map +1 -0
- package/dist/reference-types.d.ts +204 -0
- package/dist/reference-types.d.ts.map +1 -0
- package/dist/reference-types.js +2 -0
- package/dist/reference-types.js.map +1 -0
- package/dist/result-types.d.ts +75 -0
- package/dist/result-types.d.ts.map +1 -0
- package/dist/result-types.js +2 -0
- package/dist/result-types.js.map +1 -0
- package/dist/run-normalization.d.ts +9 -0
- package/dist/run-normalization.d.ts.map +1 -0
- package/dist/run-normalization.js +126 -0
- package/dist/run-normalization.js.map +1 -0
- package/dist/run-records.d.ts +8 -0
- package/dist/run-records.d.ts.map +1 -0
- package/dist/run-records.js +145 -0
- package/dist/run-records.js.map +1 -0
- package/dist/run-store-shards-runtime.d.ts +3 -0
- package/dist/run-store-shards-runtime.d.ts.map +1 -0
- package/dist/run-store-shards-runtime.js +54 -0
- package/dist/run-store-shards-runtime.js.map +1 -0
- package/dist/run-types.d.ts +112 -0
- package/dist/run-types.d.ts.map +1 -0
- package/dist/run-types.js +2 -0
- package/dist/run-types.js.map +1 -0
- package/dist/scheduler.d.ts +94 -0
- package/dist/scheduler.d.ts.map +1 -0
- package/dist/scheduler.js +213 -0
- package/dist/scheduler.js.map +1 -0
- package/dist/semantic-normalization.d.ts +3 -0
- package/dist/semantic-normalization.d.ts.map +1 -0
- package/dist/semantic-normalization.js +162 -0
- package/dist/semantic-normalization.js.map +1 -0
- package/dist/semantic-types.d.ts +229 -0
- package/dist/semantic-types.d.ts.map +1 -0
- package/dist/semantic-types.js +2 -0
- package/dist/semantic-types.js.map +1 -0
- package/dist/status-types.d.ts +28 -0
- package/dist/status-types.d.ts.map +1 -0
- package/dist/status-types.js +2 -0
- package/dist/status-types.js.map +1 -0
- package/dist/task-types.d.ts +165 -0
- package/dist/task-types.d.ts.map +1 -0
- package/dist/task-types.js +2 -0
- package/dist/task-types.js.map +1 -0
- package/dist/trace-helpers.d.ts +22 -0
- package/dist/trace-helpers.d.ts.map +1 -0
- package/dist/trace-helpers.js +181 -0
- package/dist/trace-helpers.js.map +1 -0
- package/dist/trace-runtime.d.ts +7 -0
- package/dist/trace-runtime.d.ts.map +1 -0
- package/dist/trace-runtime.js +196 -0
- package/dist/trace-runtime.js.map +1 -0
- package/dist/trace-types.d.ts +168 -0
- package/dist/trace-types.d.ts.map +1 -0
- package/dist/trace-types.js +2 -0
- package/dist/trace-types.js.map +1 -0
- package/dist/types.d.ts +19 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/usage-governor.d.ts +41 -0
- package/dist/usage-governor.d.ts.map +1 -0
- package/dist/usage-governor.js +43 -0
- package/dist/usage-governor.js.map +1 -0
- package/package.json +6 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load-observations.d.ts","sourceRoot":"","sources":["../src/adaptive-load-observations.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,KAAK,EAAE,iCAAiC,EAAE,MAAM,kCAAkC,CAAC;AAC1F,OAAO,KAAK,EACV,mCAAmC,EACnC,gCAAgC,EAChC,qCAAqC,EAGtC,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,2BAA2B,EAAE,uBAAuB,EAAE,gBAAgB,EAAsC,MAAM,YAAY,CAAC;AAE7I,wBAAgB,6BAA6B,CAC3C,KAAK,EAAE,SAAS,qCAAqC,EAAE,EACvD,WAAW,EAAE,MAAM,GAClB,gCAAgC,EAAE,CAwBpC;AAED,wBAAgB,kCAAkC,CAAC,QAAQ,EAAE,qBAAqB,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,qCAAqC,EAAE,CAsBnJ;AAED,wBAAgB,6BAA6B,CAAC,GAAG,EAAE,gBAAgB,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,qCAAqC,EAAE,CAuBpI;AAED,wBAAgB,oCAAoC,CAAC,KAAK,EAAE,uBAAuB,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,qCAAqC,EAAE,CAoBpJ;AAED,wBAAgB,mCAAmC,CAAC,SAAS,EAAE,iCAAiC,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,qCAAqC,EAAE,CAkBjK;AAED,wBAAgB,mCAAmC,CAAC,SAAS,EAAE,2BAA2B,GAAG,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,qCAAqC,EAAE,CAkB3J;AAED,wBAAgB,0CAA0C,CAAC,WAAW,EAAE,gCAAgC,GAAG,OAAO,CASjH;AAED,wBAAgB,yCAAyC,CAAC,WAAW,EAAE,gCAAgC,GAAG,OAAO,CAKhH;AAED,wBAAgB,oCAAoC,CAAC,WAAW,EAAE,gCAAgC,GAAG,mCAAmC,CAOvI;AAED,wBAAgB,iCAAiC,CAAC,WAAW,EAAE,gCAAgC,GAAG,MAAM,GAAG,SAAS,CAOnH;AAED,wBAAgB,+BAA+B,CAAC,WAAW,EAAE,gCAAgC,GAAG,OAAO,CAQtG"}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import { stableHash, toJsonObject, uniqueStrings } from './internal.js';
|
|
2
|
+
export function normalizeAdaptiveObservations(input, generatedAt) {
|
|
3
|
+
const out = [];
|
|
4
|
+
input.forEach((entry, index) => {
|
|
5
|
+
const reasons = uniqueStrings([...(entry.reason ? [entry.reason] : []), ...(entry.reasons ?? [])]);
|
|
6
|
+
const at = entry.at ?? generatedAt;
|
|
7
|
+
out.push({
|
|
8
|
+
id: entry.id ?? 'swarm-adaptive-observation:' + stableHash([entry.kind, entry.jobId, entry.lane, entry.resource, reasons, index, at]),
|
|
9
|
+
kind: entry.kind,
|
|
10
|
+
severity: entry.severity ?? adaptiveDefaultSeverity(entry.kind),
|
|
11
|
+
at,
|
|
12
|
+
value: Number.isFinite(entry.value) ? Number(entry.value) : 1,
|
|
13
|
+
...(entry.jobId ? { jobId: entry.jobId } : {}),
|
|
14
|
+
...(entry.taskId ? { taskId: entry.taskId } : {}),
|
|
15
|
+
...(entry.lane ? { lane: entry.lane } : {}),
|
|
16
|
+
...(entry.compute ? { compute: entry.compute } : {}),
|
|
17
|
+
...(entry.concurrencyKey ? { concurrencyKey: entry.concurrencyKey } : {}),
|
|
18
|
+
...(entry.resource ? { resource: entry.resource } : {}),
|
|
19
|
+
...(entry.path ? { path: entry.path } : {}),
|
|
20
|
+
...(entry.region ? { region: entry.region } : {}),
|
|
21
|
+
reasons: reasons.length ? reasons : [entry.kind],
|
|
22
|
+
...(toJsonObject(entry.metadata) ? { metadata: toJsonObject(entry.metadata) } : {})
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
return dedupeAdaptiveObservations(out);
|
|
26
|
+
}
|
|
27
|
+
export function deriveAdaptiveScheduleObservations(schedule, at) {
|
|
28
|
+
if (!schedule)
|
|
29
|
+
return [];
|
|
30
|
+
const observations = [];
|
|
31
|
+
for (const blocked of schedule.blocked) {
|
|
32
|
+
for (const reason of blocked.reasons) {
|
|
33
|
+
if (reason === 'waiting-for-dependencies')
|
|
34
|
+
continue;
|
|
35
|
+
const resource = reason.startsWith('resource-capacity:') ? reason.slice('resource-capacity:'.length) : undefined;
|
|
36
|
+
observations.push({
|
|
37
|
+
kind: resource ? 'resource-capacity' : reason,
|
|
38
|
+
severity: reason === 'ready-capacity' ? 'info' : 'warning',
|
|
39
|
+
at,
|
|
40
|
+
jobId: blocked.jobId,
|
|
41
|
+
taskId: blocked.taskId,
|
|
42
|
+
lane: blocked.lane,
|
|
43
|
+
compute: blocked.compute,
|
|
44
|
+
concurrencyKey: blocked.concurrencyKey,
|
|
45
|
+
...(resource ? { resource } : {}),
|
|
46
|
+
reason
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return observations;
|
|
51
|
+
}
|
|
52
|
+
export function deriveAdaptiveRunObservations(run, at) {
|
|
53
|
+
if (!run)
|
|
54
|
+
return [];
|
|
55
|
+
const observations = [];
|
|
56
|
+
for (const result of run.results) {
|
|
57
|
+
if (result.status === 'failed' || result.exitCode !== undefined && result.exitCode !== 0 || result.verification.some((entry) => entry.required !== false && entry.status !== undefined && entry.status !== 0)) {
|
|
58
|
+
observations.push({ kind: 'evidence-failure', severity: 'error', at, jobId: result.jobId, reason: 'worker failed or required evidence command failed' });
|
|
59
|
+
}
|
|
60
|
+
if (result.mergeDisposition === 'discovery-only' || result.mergeReadiness === 'discovery-only') {
|
|
61
|
+
observations.push({ kind: 'discovery-only-output', severity: 'info', at, jobId: result.jobId, reason: 'worker produced discovery output instead of a mergeable patch' });
|
|
62
|
+
}
|
|
63
|
+
if (semanticSummaryIsEmpty(result.semanticImport)) {
|
|
64
|
+
observations.push({ kind: 'semantic-empty', severity: 'warning', at, jobId: result.jobId, reason: 'semantic import emitted no selected/imported files or symbols' });
|
|
65
|
+
}
|
|
66
|
+
else if (semanticSummaryIsWeak(result.semanticImport)) {
|
|
67
|
+
observations.push({ kind: 'semantic-weak', severity: 'info', at, jobId: result.jobId, reason: 'semantic import has limited source maps, regions, or patch hints' });
|
|
68
|
+
}
|
|
69
|
+
if (result.durationMs !== undefined && result.durationMs > 900000) {
|
|
70
|
+
observations.push({ kind: 'slow-job', severity: 'warning', at, jobId: result.jobId, value: result.durationMs, reason: 'worker duration exceeded adaptive slow-job threshold' });
|
|
71
|
+
}
|
|
72
|
+
if ((result.status === 'completed' || result.status === 'verified') && result.exitCode === 0 && result.changedPaths.length > 0 && result.mergeDisposition !== 'discovery-only') {
|
|
73
|
+
observations.push({ kind: 'healthy-throughput', severity: 'info', at, jobId: result.jobId, reason: 'worker completed with changed paths' });
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return observations;
|
|
77
|
+
}
|
|
78
|
+
export function deriveAdaptiveMergeIndexObservations(index, at) {
|
|
79
|
+
if (!index)
|
|
80
|
+
return [];
|
|
81
|
+
const observations = [];
|
|
82
|
+
for (const entry of index.entries) {
|
|
83
|
+
if (entry.staleAgainstHead || entry.disposition === 'stale-against-head') {
|
|
84
|
+
observations.push({ kind: 'stale-patch', severity: 'warning', at, jobId: entry.jobId, lane: entry.lane, path: entry.changedPaths[0], region: entry.changedRegions[0], reason: 'patch is stale against coordinator head' });
|
|
85
|
+
}
|
|
86
|
+
if (entry.conflictingJobIds.length) {
|
|
87
|
+
observations.push({ kind: 'merge-conflict', severity: 'warning', at, jobId: entry.jobId, lane: entry.lane, path: entry.changedPaths[0], region: entry.changedRegions[0], value: entry.conflictingJobIds.length, reason: 'merge index found conflicting changed paths or regions' });
|
|
88
|
+
}
|
|
89
|
+
if (entry.disposition === 'discovery-only') {
|
|
90
|
+
observations.push({ kind: 'discovery-only-output', severity: 'info', at, jobId: entry.jobId, lane: entry.lane, reason: 'merge index classified the bundle as discovery-only' });
|
|
91
|
+
}
|
|
92
|
+
if (semanticSummaryIsEmpty(entry.semanticImport)) {
|
|
93
|
+
observations.push({ kind: 'semantic-empty', severity: 'warning', at, jobId: entry.jobId, lane: entry.lane, reason: 'semantic sidecar is present but empty' });
|
|
94
|
+
}
|
|
95
|
+
else if (semanticSummaryIsWeak(entry.semanticImport)) {
|
|
96
|
+
observations.push({ kind: 'semantic-weak', severity: 'info', at, jobId: entry.jobId, lane: entry.lane, reason: 'semantic sidecar lacks merge-useful structure' });
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
return observations;
|
|
100
|
+
}
|
|
101
|
+
export function deriveAdaptiveDashboardObservations(dashboard, at) {
|
|
102
|
+
if (!dashboard)
|
|
103
|
+
return [];
|
|
104
|
+
const observations = [];
|
|
105
|
+
for (const job of dashboard.jobs) {
|
|
106
|
+
if (job.duplicateGroupId) {
|
|
107
|
+
observations.push({ kind: 'duplicate-output', severity: 'info', at, jobId: job.jobId, lane: job.lane, path: job.changedPaths[0], region: job.changedRegions[0], reason: 'coordinator dashboard found duplicate worker output' });
|
|
108
|
+
}
|
|
109
|
+
if (job.tests.requiredFailed > 0) {
|
|
110
|
+
observations.push({ kind: 'evidence-failure', severity: 'error', at, jobId: job.jobId, lane: job.lane, reason: 'dashboard shows required evidence failures' });
|
|
111
|
+
}
|
|
112
|
+
if (job.staleAgainstHead) {
|
|
113
|
+
observations.push({ kind: 'stale-patch', severity: 'warning', at, jobId: job.jobId, lane: job.lane, path: job.changedPaths[0], reason: 'dashboard marks patch stale against head' });
|
|
114
|
+
}
|
|
115
|
+
if (semanticSummaryIsEmpty(job.semanticImport)) {
|
|
116
|
+
observations.push({ kind: 'semantic-empty', severity: 'warning', at, jobId: job.jobId, lane: job.lane, reason: 'dashboard semantic import summary is empty' });
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return observations;
|
|
120
|
+
}
|
|
121
|
+
export function deriveAdaptiveAdmissionObservations(admission, at) {
|
|
122
|
+
if (!admission)
|
|
123
|
+
return [];
|
|
124
|
+
const observations = [];
|
|
125
|
+
for (const deferral of admission.deferred) {
|
|
126
|
+
for (const reason of deferral.reasons) {
|
|
127
|
+
const kind = reason === 'stale-against-head'
|
|
128
|
+
? 'stale-patch'
|
|
129
|
+
: reason === 'conflicting-changes'
|
|
130
|
+
? 'merge-conflict'
|
|
131
|
+
: reason === 'not-auto-mergeable'
|
|
132
|
+
? 'discovery-only-output'
|
|
133
|
+
: reason === 'max-ready'
|
|
134
|
+
? 'ready-capacity'
|
|
135
|
+
: 'budget-pressure';
|
|
136
|
+
observations.push({ kind, severity: kind === 'ready-capacity' ? 'info' : 'warning', at, jobId: deferral.jobId, reason: `merge admission deferred: ${reason}` });
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return observations;
|
|
140
|
+
}
|
|
141
|
+
export function adaptiveObservationShouldReduceReadyWindow(observation) {
|
|
142
|
+
return observation.kind === 'evidence-failure'
|
|
143
|
+
|| observation.kind === 'stale-patch'
|
|
144
|
+
|| observation.kind === 'browser-contention'
|
|
145
|
+
|| observation.kind === 'semantic-empty'
|
|
146
|
+
|| observation.kind === 'log-noise'
|
|
147
|
+
|| observation.kind === 'discovery-only-output'
|
|
148
|
+
|| observation.kind === 'budget-pressure'
|
|
149
|
+
|| observation.kind === 'slow-job';
|
|
150
|
+
}
|
|
151
|
+
export function adaptiveObservationIsCapacityBackpressure(observation) {
|
|
152
|
+
return observation.kind === 'resource-capacity'
|
|
153
|
+
|| observation.kind === 'lane-capacity'
|
|
154
|
+
|| observation.kind === 'concurrency-key-capacity'
|
|
155
|
+
|| observation.kind === 'compute-capacity';
|
|
156
|
+
}
|
|
157
|
+
export function adaptiveDecisionTargetForObservation(observation) {
|
|
158
|
+
if (observation.kind === 'resource-capacity' || observation.kind === 'browser-contention')
|
|
159
|
+
return 'resource';
|
|
160
|
+
if (observation.kind === 'lane-capacity')
|
|
161
|
+
return 'lane';
|
|
162
|
+
if (observation.kind === 'concurrency-key-capacity' || observation.kind === 'merge-conflict' || observation.kind === 'duplicate-output')
|
|
163
|
+
return 'concurrency-key';
|
|
164
|
+
if (observation.kind === 'compute-capacity')
|
|
165
|
+
return 'compute';
|
|
166
|
+
if (observation.lane)
|
|
167
|
+
return 'lane';
|
|
168
|
+
return 'max-ready-jobs';
|
|
169
|
+
}
|
|
170
|
+
export function adaptiveDecisionKeyForObservation(observation) {
|
|
171
|
+
const target = adaptiveDecisionTargetForObservation(observation);
|
|
172
|
+
if (target === 'resource')
|
|
173
|
+
return observation.resource ?? (observation.kind === 'browser-contention' ? 'browser' : undefined);
|
|
174
|
+
if (target === 'lane')
|
|
175
|
+
return observation.lane;
|
|
176
|
+
if (target === 'concurrency-key')
|
|
177
|
+
return observation.concurrencyKey ?? observation.region ?? observation.path;
|
|
178
|
+
if (target === 'compute')
|
|
179
|
+
return observation.compute;
|
|
180
|
+
return undefined;
|
|
181
|
+
}
|
|
182
|
+
export function adaptiveObservationIsBottleneck(observation) {
|
|
183
|
+
if (observation.kind === 'healthy-throughput' || observation.kind === 'ready-capacity')
|
|
184
|
+
return false;
|
|
185
|
+
return observation.severity !== 'info'
|
|
186
|
+
|| observation.kind === 'merge-conflict'
|
|
187
|
+
|| observation.kind === 'stale-patch'
|
|
188
|
+
|| observation.kind === 'semantic-empty'
|
|
189
|
+
|| observation.kind === 'log-noise'
|
|
190
|
+
|| observation.kind === 'duplicate-output';
|
|
191
|
+
}
|
|
192
|
+
function adaptiveDefaultSeverity(kind) {
|
|
193
|
+
if (kind === 'evidence-failure' || kind === 'budget-pressure')
|
|
194
|
+
return 'error';
|
|
195
|
+
if (kind === 'merge-conflict' || kind === 'stale-patch' || kind === 'semantic-empty' || kind === 'browser-contention' || kind.endsWith('-capacity'))
|
|
196
|
+
return 'warning';
|
|
197
|
+
return 'info';
|
|
198
|
+
}
|
|
199
|
+
function semanticSummaryIsEmpty(summary) {
|
|
200
|
+
if (!summary)
|
|
201
|
+
return false;
|
|
202
|
+
return summary.total === 0
|
|
203
|
+
|| summary.selected === 0 && summary.eligible === 0 && summary.imported === 0 && summary.semanticIndex.symbols === 0 && summary.semanticSidecars.symbols === 0;
|
|
204
|
+
}
|
|
205
|
+
function semanticSummaryIsWeak(summary) {
|
|
206
|
+
if (!summary || semanticSummaryIsEmpty(summary))
|
|
207
|
+
return false;
|
|
208
|
+
return summary.imported === 0
|
|
209
|
+
|| summary.semanticIndex.symbols === 0
|
|
210
|
+
|| summary.semanticSidecars.ownershipRegions === 0
|
|
211
|
+
|| summary.sourceMapMappingCount === 0
|
|
212
|
+
|| summary.proofSpec.failed > 0
|
|
213
|
+
|| summary.proofSpec.stale > 0
|
|
214
|
+
|| summary.proofSpec.open > 0
|
|
215
|
+
|| summary.proofSpec.unknown > 0;
|
|
216
|
+
}
|
|
217
|
+
function dedupeAdaptiveObservations(observations) {
|
|
218
|
+
const byKey = new Map();
|
|
219
|
+
for (const observation of observations) {
|
|
220
|
+
const key = [
|
|
221
|
+
observation.kind,
|
|
222
|
+
observation.jobId ?? '',
|
|
223
|
+
observation.lane ?? '',
|
|
224
|
+
observation.compute ?? '',
|
|
225
|
+
observation.concurrencyKey ?? '',
|
|
226
|
+
observation.resource ?? '',
|
|
227
|
+
observation.path ?? '',
|
|
228
|
+
observation.region ?? '',
|
|
229
|
+
observation.reasons.join('|')
|
|
230
|
+
].join('\0');
|
|
231
|
+
const existing = byKey.get(key);
|
|
232
|
+
if (!existing || adaptiveSeverityRank(observation.severity) > adaptiveSeverityRank(existing.severity))
|
|
233
|
+
byKey.set(key, observation);
|
|
234
|
+
}
|
|
235
|
+
return Array.from(byKey.values()).sort((left, right) => adaptiveSeverityRank(right.severity) - adaptiveSeverityRank(left.severity) || left.kind.localeCompare(right.kind) || (left.jobId ?? '').localeCompare(right.jobId ?? ''));
|
|
236
|
+
}
|
|
237
|
+
function adaptiveSeverityRank(severity) {
|
|
238
|
+
if (severity === 'critical')
|
|
239
|
+
return 4;
|
|
240
|
+
if (severity === 'error')
|
|
241
|
+
return 3;
|
|
242
|
+
if (severity === 'warning')
|
|
243
|
+
return 2;
|
|
244
|
+
if (severity === 'info')
|
|
245
|
+
return 1;
|
|
246
|
+
return 0;
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=adaptive-load-observations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load-observations.js","sourceRoot":"","sources":["../src/adaptive-load-observations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import type { JsonObject } from '@shapeshift-labs/frontier';
|
|
2
|
+
import type { FrontierSwarmPlan, FrontierSwarmScheduleLimits } from './plan.js';
|
|
3
|
+
import type { FrontierSwarmSchedule } from './scheduler.js';
|
|
4
|
+
import type { FrontierSwarmCoordinatorDashboard } from './coordinator-dashboard-types.js';
|
|
5
|
+
import type { FrontierSwarmMergeAdmission, FrontierSwarmMergeIndex, FrontierSwarmRun } from './index.js';
|
|
6
|
+
export declare const FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND = "frontier.swarm.adaptive-load-plan";
|
|
7
|
+
export declare const FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION = 1;
|
|
8
|
+
export type FrontierSwarmAdaptiveMode = 'off' | 'observe' | 'conservative' | 'balanced' | 'aggressive' | string;
|
|
9
|
+
export type FrontierSwarmAdaptiveObservationKind = 'resource-capacity' | 'lane-capacity' | 'concurrency-key-capacity' | 'compute-capacity' | 'ready-capacity' | 'evidence-failure' | 'merge-conflict' | 'stale-patch' | 'browser-contention' | 'semantic-empty' | 'semantic-weak' | 'log-noise' | 'discovery-only-output' | 'duplicate-output' | 'budget-pressure' | 'slow-job' | 'healthy-throughput' | string;
|
|
10
|
+
export type FrontierSwarmAdaptiveObservationSeverity = 'info' | 'warning' | 'error' | 'critical' | string;
|
|
11
|
+
export type FrontierSwarmAdaptiveDecisionAction = 'observe' | 'decrease' | 'increase' | 'hold' | string;
|
|
12
|
+
export type FrontierSwarmAdaptiveDecisionTarget = 'max-ready-jobs' | 'lane' | 'concurrency-key' | 'compute' | 'resource' | string;
|
|
13
|
+
export interface FrontierSwarmAdaptiveScheduleLimitsInput {
|
|
14
|
+
maxReadyJobs?: number;
|
|
15
|
+
maxLaneConcurrency?: Record<string, number>;
|
|
16
|
+
maxConcurrencyKeyConcurrency?: Record<string, number>;
|
|
17
|
+
maxComputeConcurrency?: Record<string, number>;
|
|
18
|
+
resourceQuotas?: Record<string, number>;
|
|
19
|
+
}
|
|
20
|
+
export interface FrontierSwarmAdaptiveObservationInput {
|
|
21
|
+
id?: string;
|
|
22
|
+
kind: FrontierSwarmAdaptiveObservationKind;
|
|
23
|
+
severity?: FrontierSwarmAdaptiveObservationSeverity;
|
|
24
|
+
at?: number;
|
|
25
|
+
value?: number;
|
|
26
|
+
jobId?: string;
|
|
27
|
+
taskId?: string;
|
|
28
|
+
lane?: string;
|
|
29
|
+
compute?: string;
|
|
30
|
+
concurrencyKey?: string;
|
|
31
|
+
resource?: string;
|
|
32
|
+
path?: string;
|
|
33
|
+
region?: string;
|
|
34
|
+
reason?: string;
|
|
35
|
+
reasons?: readonly string[];
|
|
36
|
+
metadata?: unknown;
|
|
37
|
+
}
|
|
38
|
+
export interface FrontierSwarmAdaptiveObservation {
|
|
39
|
+
id: string;
|
|
40
|
+
kind: FrontierSwarmAdaptiveObservationKind;
|
|
41
|
+
severity: FrontierSwarmAdaptiveObservationSeverity;
|
|
42
|
+
at: number;
|
|
43
|
+
value: number;
|
|
44
|
+
jobId?: string;
|
|
45
|
+
taskId?: string;
|
|
46
|
+
lane?: string;
|
|
47
|
+
compute?: string;
|
|
48
|
+
concurrencyKey?: string;
|
|
49
|
+
resource?: string;
|
|
50
|
+
path?: string;
|
|
51
|
+
region?: string;
|
|
52
|
+
reasons: string[];
|
|
53
|
+
metadata?: JsonObject;
|
|
54
|
+
}
|
|
55
|
+
export interface FrontierSwarmAdaptiveLoadPlanInput {
|
|
56
|
+
id?: string;
|
|
57
|
+
plan?: FrontierSwarmPlan;
|
|
58
|
+
run?: FrontierSwarmRun;
|
|
59
|
+
schedule?: FrontierSwarmSchedule;
|
|
60
|
+
mergeIndex?: FrontierSwarmMergeIndex;
|
|
61
|
+
dashboard?: FrontierSwarmCoordinatorDashboard;
|
|
62
|
+
admission?: FrontierSwarmMergeAdmission;
|
|
63
|
+
mode?: FrontierSwarmAdaptiveMode;
|
|
64
|
+
maxLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
65
|
+
currentLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
66
|
+
minLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
67
|
+
observations?: readonly FrontierSwarmAdaptiveObservationInput[];
|
|
68
|
+
generatedAt?: number;
|
|
69
|
+
metadata?: unknown;
|
|
70
|
+
}
|
|
71
|
+
export interface FrontierSwarmAdaptiveLoadDecision {
|
|
72
|
+
id: string;
|
|
73
|
+
action: FrontierSwarmAdaptiveDecisionAction;
|
|
74
|
+
target: FrontierSwarmAdaptiveDecisionTarget;
|
|
75
|
+
key?: string;
|
|
76
|
+
previous?: number;
|
|
77
|
+
next?: number;
|
|
78
|
+
max?: number;
|
|
79
|
+
min?: number;
|
|
80
|
+
reason: string;
|
|
81
|
+
observationIds: string[];
|
|
82
|
+
}
|
|
83
|
+
export interface FrontierSwarmAdaptiveLoadPlan {
|
|
84
|
+
kind: typeof FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND;
|
|
85
|
+
version: typeof FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION;
|
|
86
|
+
id: string;
|
|
87
|
+
planId?: string;
|
|
88
|
+
runId?: string;
|
|
89
|
+
mode: FrontierSwarmAdaptiveMode;
|
|
90
|
+
generatedAt: number;
|
|
91
|
+
maxLimits: FrontierSwarmScheduleLimits;
|
|
92
|
+
currentLimits: FrontierSwarmScheduleLimits;
|
|
93
|
+
minLimits: FrontierSwarmScheduleLimits;
|
|
94
|
+
effectiveLimits: FrontierSwarmScheduleLimits;
|
|
95
|
+
observations: FrontierSwarmAdaptiveObservation[];
|
|
96
|
+
decisions: FrontierSwarmAdaptiveLoadDecision[];
|
|
97
|
+
summary: {
|
|
98
|
+
observationCount: number;
|
|
99
|
+
bottleneckCount: number;
|
|
100
|
+
decisionCount: number;
|
|
101
|
+
reducedCount: number;
|
|
102
|
+
increasedCount: number;
|
|
103
|
+
effectiveMaxReadyJobs?: number;
|
|
104
|
+
maxReadyJobs?: number;
|
|
105
|
+
};
|
|
106
|
+
metadata?: JsonObject;
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=adaptive-load-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load-types.d.ts","sourceRoot":"","sources":["../src/adaptive-load-types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load-types.js","sourceRoot":"","sources":["../src/adaptive-load-types.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,sCAAsC,GAAG,mCAAmC,CAAC;AAC1F,MAAM,CAAC,MAAM,yCAAyC,GAAG,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { FrontierSwarmPlan } from './plan.js';
|
|
2
|
+
import type { FrontierSwarmScheduleInput } from './scheduler.js';
|
|
3
|
+
import type { FrontierSwarmRun } from './index.js';
|
|
4
|
+
import type { FrontierSwarmAdaptiveLoadPlan, FrontierSwarmAdaptiveLoadPlanInput } from './adaptive-load-types.js';
|
|
5
|
+
export declare function createSwarmAdaptiveLoadPlan(input?: FrontierSwarmAdaptiveLoadPlanInput): FrontierSwarmAdaptiveLoadPlan;
|
|
6
|
+
export declare function createSwarmScheduleInputFromAdaptiveLoadPlan(plan: FrontierSwarmPlan, adaptive: FrontierSwarmAdaptiveLoadPlan, input?: {
|
|
7
|
+
run?: FrontierSwarmRun;
|
|
8
|
+
now?: number;
|
|
9
|
+
}): FrontierSwarmScheduleInput;
|
|
10
|
+
//# sourceMappingURL=adaptive-load.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load.d.ts","sourceRoot":"","sources":["../src/adaptive-load.ts"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,iBAAiB,EAA+B,MAAM,WAAW,CAAC;AAChF,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,gBAAgB,CAAC;AACjE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,KAAK,EAEV,6BAA6B,EAC7B,kCAAkC,EACnC,MAAM,0BAA0B,CAAC;AAElC,wBAAgB,2BAA2B,CAAC,KAAK,GAAE,kCAAuC,GAAG,6BAA6B,CAmEzH;AAED,wBAAgB,4CAA4C,CAC1D,IAAI,EAAE,iBAAiB,EACvB,QAAQ,EAAE,6BAA6B,EACvC,KAAK,GAAE;IAAE,GAAG,CAAC,EAAE,gBAAgB,CAAC;IAAC,GAAG,CAAC,EAAE,MAAM,CAAA;CAAO,GACnD,0BAA0B,CAW5B"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { cloneJsonValue, stableHash, toJsonObject } from './internal.js';
|
|
2
|
+
import { createSwarmSchedule } from './scheduler.js';
|
|
3
|
+
import { clampAdaptiveLimits, createAdaptiveCurrentLimits, createAdaptiveMaxLimits, createAdaptiveMinLimits } from './adaptive-load-limits.js';
|
|
4
|
+
import { adaptiveDecisionKeyForObservation, adaptiveDecisionTargetForObservation, adaptiveObservationIsBottleneck, deriveAdaptiveAdmissionObservations, deriveAdaptiveDashboardObservations, deriveAdaptiveMergeIndexObservations, deriveAdaptiveRunObservations, deriveAdaptiveScheduleObservations, normalizeAdaptiveObservations } from './adaptive-load-observations.js';
|
|
5
|
+
import { applyAdaptiveObservation, applyAdaptiveRecovery, createAdaptiveDecision } from './adaptive-load-decisions.js';
|
|
6
|
+
import { FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND, FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION } from './adaptive-load-types.js';
|
|
7
|
+
export function createSwarmAdaptiveLoadPlan(input = {}) {
|
|
8
|
+
const generatedAt = input.generatedAt ?? Date.now();
|
|
9
|
+
const mode = input.mode ?? 'balanced';
|
|
10
|
+
const maxLimits = createAdaptiveMaxLimits(input);
|
|
11
|
+
const minLimits = createAdaptiveMinLimits(input.minLimits, maxLimits);
|
|
12
|
+
const currentLimits = clampAdaptiveLimits(createAdaptiveCurrentLimits(input.currentLimits, maxLimits), minLimits, maxLimits);
|
|
13
|
+
const effectiveLimits = mode === 'off'
|
|
14
|
+
? cloneJsonValue(maxLimits)
|
|
15
|
+
: cloneJsonValue(currentLimits);
|
|
16
|
+
const schedule = input.schedule ?? (input.plan ? createSwarmSchedule({ plan: input.plan, run: input.run }) : undefined);
|
|
17
|
+
const observations = normalizeAdaptiveObservations([
|
|
18
|
+
...deriveAdaptiveScheduleObservations(schedule, generatedAt),
|
|
19
|
+
...deriveAdaptiveRunObservations(input.run, generatedAt),
|
|
20
|
+
...deriveAdaptiveMergeIndexObservations(input.mergeIndex, generatedAt),
|
|
21
|
+
...deriveAdaptiveDashboardObservations(input.dashboard, generatedAt),
|
|
22
|
+
...deriveAdaptiveAdmissionObservations(input.admission, generatedAt),
|
|
23
|
+
...(input.observations ?? [])
|
|
24
|
+
], generatedAt);
|
|
25
|
+
const decisions = [];
|
|
26
|
+
const bottlenecks = observations.filter((observation) => adaptiveObservationIsBottleneck(observation));
|
|
27
|
+
if (mode === 'observe') {
|
|
28
|
+
for (const observation of bottlenecks) {
|
|
29
|
+
decisions.push(createAdaptiveDecision({
|
|
30
|
+
action: 'observe',
|
|
31
|
+
target: adaptiveDecisionTargetForObservation(observation),
|
|
32
|
+
key: adaptiveDecisionKeyForObservation(observation),
|
|
33
|
+
reason: observation.reasons[0] ?? observation.kind,
|
|
34
|
+
observationIds: [observation.id]
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
else if (mode !== 'off') {
|
|
39
|
+
for (const observation of bottlenecks) {
|
|
40
|
+
applyAdaptiveObservation(effectiveLimits, minLimits, maxLimits, mode, observation, decisions);
|
|
41
|
+
}
|
|
42
|
+
const healthy = observations.filter((observation) => observation.kind === 'healthy-throughput');
|
|
43
|
+
if (bottlenecks.length === 0 && healthy.length > 0) {
|
|
44
|
+
for (const observation of healthy)
|
|
45
|
+
applyAdaptiveRecovery(effectiveLimits, maxLimits, observation, decisions);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
const summary = {
|
|
49
|
+
observationCount: observations.length,
|
|
50
|
+
bottleneckCount: bottlenecks.length,
|
|
51
|
+
decisionCount: decisions.length,
|
|
52
|
+
reducedCount: decisions.filter((decision) => decision.action === 'decrease').length,
|
|
53
|
+
increasedCount: decisions.filter((decision) => decision.action === 'increase').length,
|
|
54
|
+
...(effectiveLimits.maxReadyJobs !== undefined ? { effectiveMaxReadyJobs: effectiveLimits.maxReadyJobs } : {}),
|
|
55
|
+
...(maxLimits.maxReadyJobs !== undefined ? { maxReadyJobs: maxLimits.maxReadyJobs } : {})
|
|
56
|
+
};
|
|
57
|
+
return {
|
|
58
|
+
kind: FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND,
|
|
59
|
+
version: FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION,
|
|
60
|
+
id: input.id ?? 'swarm-adaptive-load-plan:' + stableHash([input.plan?.id, input.run?.id, mode, observations, decisions, generatedAt]),
|
|
61
|
+
...(input.plan?.id ? { planId: input.plan.id } : {}),
|
|
62
|
+
...(input.run?.id ? { runId: input.run.id } : {}),
|
|
63
|
+
mode,
|
|
64
|
+
generatedAt,
|
|
65
|
+
maxLimits,
|
|
66
|
+
currentLimits,
|
|
67
|
+
minLimits,
|
|
68
|
+
effectiveLimits,
|
|
69
|
+
observations,
|
|
70
|
+
decisions,
|
|
71
|
+
summary,
|
|
72
|
+
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
export function createSwarmScheduleInputFromAdaptiveLoadPlan(plan, adaptive, input = {}) {
|
|
76
|
+
return {
|
|
77
|
+
plan,
|
|
78
|
+
...(input.run ? { run: input.run } : {}),
|
|
79
|
+
...(input.now !== undefined ? { now: input.now } : {}),
|
|
80
|
+
...(adaptive.effectiveLimits.maxReadyJobs !== undefined ? { maxReadyJobs: adaptive.effectiveLimits.maxReadyJobs } : {}),
|
|
81
|
+
maxLaneConcurrency: adaptive.effectiveLimits.maxLaneConcurrency,
|
|
82
|
+
maxConcurrencyKeyConcurrency: adaptive.effectiveLimits.maxConcurrencyKeyConcurrency,
|
|
83
|
+
maxComputeConcurrency: adaptive.effectiveLimits.maxComputeConcurrency,
|
|
84
|
+
resourceQuotas: adaptive.effectiveLimits.resourceQuotas
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=adaptive-load.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adaptive-load.js","sourceRoot":"","sources":["../src/adaptive-load.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EACL,mBAAmB,EACnB,2BAA2B,EAC3B,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EACL,iCAAiC,EACjC,oCAAoC,EACpC,+BAA+B,EAC/B,mCAAmC,EACnC,mCAAmC,EACnC,oCAAoC,EACpC,6BAA6B,EAC7B,kCAAkC,EAClC,6BAA6B,EAC9B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,wBAAwB,EAAE,qBAAqB,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AACvH,OAAO,EACL,sCAAsC,EACtC,yCAAyC,EAC1C,MAAM,0BAA0B,CAAC;AAUlC,MAAM,UAAU,2BAA2B,CAAC,QAA4C,EAAE;IACxF,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;IACpD,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,UAAU,CAAC;IACtC,MAAM,SAAS,GAAG,uBAAuB,CAAC,KAAK,CAAC,CAAC;IACjD,MAAM,SAAS,GAAG,uBAAuB,CAAC,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IACtE,MAAM,aAAa,GAAG,mBAAmB,CAAC,2BAA2B,CAAC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IAC7H,MAAM,eAAe,GAAG,IAAI,KAAK,KAAK;QACpC,CAAC,CAAC,cAAc,CAAC,SAAS,CAAgC;QAC1D,CAAC,CAAC,cAAc,CAAC,aAAa,CAAgC,CAAC;IACjE,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,mBAAmB,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IACxH,MAAM,YAAY,GAAG,6BAA6B,CAAC;QACjD,GAAG,kCAAkC,CAAC,QAAQ,EAAE,WAAW,CAAC;QAC5D,GAAG,6BAA6B,CAAC,KAAK,CAAC,GAAG,EAAE,WAAW,CAAC;QACxD,GAAG,oCAAoC,CAAC,KAAK,CAAC,UAAU,EAAE,WAAW,CAAC;QACtE,GAAG,mCAAmC,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,CAAC;QACpE,GAAG,mCAAmC,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,CAAC;QACpE,GAAG,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC;KAC9B,EAAE,WAAW,CAAC,CAAC;IAChB,MAAM,SAAS,GAAwC,EAAE,CAAC;IAC1D,MAAM,WAAW,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,+BAA+B,CAAC,WAAW,CAAC,CAAC,CAAC;IAEvG,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACvB,KAAK,MAAM,WAAW,IAAI,WAAW,EAAE,CAAC;YACtC,SAAS,CAAC,IAAI,CAAC,sBAAsB,CAAC;gBACpC,MAAM,EAAE,SAAS;gBACjB,MAAM,EAAE,oCAAoC,CAAC,WAAW,CAAC;gBACzD,GAAG,EAAE,iCAAiC,CAAC,WAAW,CAAC;gBACnD,MAAM,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,WAAW,CAAC,IAAI;gBAClD,cAAc,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC;aACjC,CAAC,CAAC,CAAC;QACN,CAAC;IACH,CAAC;SAAM,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;QAC1B,KAAK,MAAM,WAAW,IAAI,WAAW,EAAE,CAAC;YACtC,wBAAwB,CAAC,eAAe,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;QAChG,CAAC;QACD,MAAM,OAAO,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,IAAI,KAAK,oBAAoB,CAAC,CAAC;QAChG,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACnD,KAAK,MAAM,WAAW,IAAI,OAAO;gBAAE,qBAAqB,CAAC,eAAe,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;QAC/G,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAG;QACd,gBAAgB,EAAE,YAAY,CAAC,MAAM;QACrC,eAAe,EAAE,WAAW,CAAC,MAAM;QACnC,aAAa,EAAE,SAAS,CAAC,MAAM;QAC/B,YAAY,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,MAAM;QACnF,cAAc,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,MAAM;QACrF,GAAG,CAAC,eAAe,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,qBAAqB,EAAE,eAAe,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9G,GAAG,CAAC,SAAS,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,SAAS,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KAC1F,CAAC;IACF,OAAO;QACL,IAAI,EAAE,sCAAsC;QAC5C,OAAO,EAAE,yCAAyC;QAClD,EAAE,EAAE,KAAK,CAAC,EAAE,IAAI,2BAA2B,GAAG,UAAU,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,CAAC,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QACrI,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACjD,IAAI;QACJ,WAAW;QACX,SAAS;QACT,aAAa;QACb,SAAS;QACT,eAAe;QACf,YAAY;QACZ,SAAS;QACT,OAAO;QACP,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACpF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,4CAA4C,CAC1D,IAAuB,EACvB,QAAuC,EACvC,QAAkD,EAAE;IAEpD,OAAO;QACL,IAAI;QACJ,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACxC,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACtD,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACvH,kBAAkB,EAAE,QAAQ,CAAC,eAAe,CAAC,kBAAkB;QAC/D,4BAA4B,EAAE,QAAQ,CAAC,eAAe,CAAC,4BAA4B;QACnF,qBAAqB,EAAE,QAAQ,CAAC,eAAe,CAAC,qBAAqB;QACrE,cAAc,EAAE,QAAQ,CAAC,eAAe,CAAC,cAAc;KACxD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import type { JsonObject } from '@shapeshift-labs/frontier';
|
|
2
|
+
import type { FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND, FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION, FRONTIER_SWARM_PROOF_KIND, FRONTIER_SWARM_PROOF_VERSION } from './constants.js';
|
|
3
|
+
import type { FrontierSwarmMergeAdmission } from './context-types.js';
|
|
4
|
+
import type { FrontierSwarmCoordinatorDashboard } from './coordinator-types.js';
|
|
5
|
+
import type { FrontierSwarmSummary } from './manifest-types.js';
|
|
6
|
+
import type { FrontierSwarmMergeIndex } from './merge-types.js';
|
|
7
|
+
import type { FrontierSwarmPlan, FrontierSwarmScheduleLimits } from './plan.js';
|
|
8
|
+
import type { FrontierSwarmRun } from './run-types.js';
|
|
9
|
+
import type { FrontierSwarmSchedule } from './scheduler.js';
|
|
10
|
+
import type { FrontierSwarmAdaptiveDecisionAction, FrontierSwarmAdaptiveDecisionTarget, FrontierSwarmAdaptiveMode, FrontierSwarmAdaptiveObservationKind, FrontierSwarmAdaptiveObservationSeverity } from './status-types.js';
|
|
11
|
+
import type { FrontierSwarmValidation } from './task-types.js';
|
|
12
|
+
export interface FrontierSwarmAdaptiveScheduleLimitsInput {
|
|
13
|
+
maxReadyJobs?: number;
|
|
14
|
+
maxLaneConcurrency?: Record<string, number>;
|
|
15
|
+
maxConcurrencyKeyConcurrency?: Record<string, number>;
|
|
16
|
+
maxComputeConcurrency?: Record<string, number>;
|
|
17
|
+
resourceQuotas?: Record<string, number>;
|
|
18
|
+
}
|
|
19
|
+
export interface FrontierSwarmAdaptiveObservationInput {
|
|
20
|
+
id?: string;
|
|
21
|
+
kind: FrontierSwarmAdaptiveObservationKind;
|
|
22
|
+
severity?: FrontierSwarmAdaptiveObservationSeverity;
|
|
23
|
+
at?: number;
|
|
24
|
+
value?: number;
|
|
25
|
+
jobId?: string;
|
|
26
|
+
taskId?: string;
|
|
27
|
+
lane?: string;
|
|
28
|
+
compute?: string;
|
|
29
|
+
concurrencyKey?: string;
|
|
30
|
+
resource?: string;
|
|
31
|
+
path?: string;
|
|
32
|
+
region?: string;
|
|
33
|
+
reason?: string;
|
|
34
|
+
reasons?: readonly string[];
|
|
35
|
+
metadata?: unknown;
|
|
36
|
+
}
|
|
37
|
+
export interface FrontierSwarmAdaptiveObservation {
|
|
38
|
+
id: string;
|
|
39
|
+
kind: FrontierSwarmAdaptiveObservationKind;
|
|
40
|
+
severity: FrontierSwarmAdaptiveObservationSeverity;
|
|
41
|
+
at: number;
|
|
42
|
+
value: number;
|
|
43
|
+
jobId?: string;
|
|
44
|
+
taskId?: string;
|
|
45
|
+
lane?: string;
|
|
46
|
+
compute?: string;
|
|
47
|
+
concurrencyKey?: string;
|
|
48
|
+
resource?: string;
|
|
49
|
+
path?: string;
|
|
50
|
+
region?: string;
|
|
51
|
+
reasons: string[];
|
|
52
|
+
metadata?: JsonObject;
|
|
53
|
+
}
|
|
54
|
+
export interface FrontierSwarmAdaptiveLoadPlanInput {
|
|
55
|
+
id?: string;
|
|
56
|
+
plan?: FrontierSwarmPlan;
|
|
57
|
+
run?: FrontierSwarmRun;
|
|
58
|
+
schedule?: FrontierSwarmSchedule;
|
|
59
|
+
mergeIndex?: FrontierSwarmMergeIndex;
|
|
60
|
+
dashboard?: FrontierSwarmCoordinatorDashboard;
|
|
61
|
+
admission?: FrontierSwarmMergeAdmission;
|
|
62
|
+
mode?: FrontierSwarmAdaptiveMode;
|
|
63
|
+
maxLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
64
|
+
currentLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
65
|
+
minLimits?: FrontierSwarmAdaptiveScheduleLimitsInput;
|
|
66
|
+
observations?: readonly FrontierSwarmAdaptiveObservationInput[];
|
|
67
|
+
generatedAt?: number;
|
|
68
|
+
metadata?: unknown;
|
|
69
|
+
}
|
|
70
|
+
export interface FrontierSwarmAdaptiveLoadDecision {
|
|
71
|
+
id: string;
|
|
72
|
+
action: FrontierSwarmAdaptiveDecisionAction;
|
|
73
|
+
target: FrontierSwarmAdaptiveDecisionTarget;
|
|
74
|
+
key?: string;
|
|
75
|
+
previous?: number;
|
|
76
|
+
next?: number;
|
|
77
|
+
max?: number;
|
|
78
|
+
min?: number;
|
|
79
|
+
reason: string;
|
|
80
|
+
observationIds: string[];
|
|
81
|
+
}
|
|
82
|
+
export interface FrontierSwarmAdaptiveLoadPlan {
|
|
83
|
+
kind: typeof FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_KIND;
|
|
84
|
+
version: typeof FRONTIER_SWARM_ADAPTIVE_LOAD_PLAN_VERSION;
|
|
85
|
+
id: string;
|
|
86
|
+
planId?: string;
|
|
87
|
+
runId?: string;
|
|
88
|
+
mode: FrontierSwarmAdaptiveMode;
|
|
89
|
+
generatedAt: number;
|
|
90
|
+
maxLimits: FrontierSwarmScheduleLimits;
|
|
91
|
+
currentLimits: FrontierSwarmScheduleLimits;
|
|
92
|
+
minLimits: FrontierSwarmScheduleLimits;
|
|
93
|
+
effectiveLimits: FrontierSwarmScheduleLimits;
|
|
94
|
+
observations: FrontierSwarmAdaptiveObservation[];
|
|
95
|
+
decisions: FrontierSwarmAdaptiveLoadDecision[];
|
|
96
|
+
summary: {
|
|
97
|
+
observationCount: number;
|
|
98
|
+
bottleneckCount: number;
|
|
99
|
+
decisionCount: number;
|
|
100
|
+
reducedCount: number;
|
|
101
|
+
increasedCount: number;
|
|
102
|
+
effectiveMaxReadyJobs?: number;
|
|
103
|
+
maxReadyJobs?: number;
|
|
104
|
+
};
|
|
105
|
+
metadata?: JsonObject;
|
|
106
|
+
}
|
|
107
|
+
export interface FrontierSwarmProof {
|
|
108
|
+
kind: typeof FRONTIER_SWARM_PROOF_KIND;
|
|
109
|
+
version: typeof FRONTIER_SWARM_PROOF_VERSION;
|
|
110
|
+
id: string;
|
|
111
|
+
manifestId: string;
|
|
112
|
+
generatedAt: number;
|
|
113
|
+
hash: string;
|
|
114
|
+
summary: FrontierSwarmSummary;
|
|
115
|
+
validation?: FrontierSwarmValidation;
|
|
116
|
+
metadata?: JsonObject;
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=adaptive-types.d.ts.map
|