@shapeshift-labs/frontier-swarm 0.5.19 → 0.5.21
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 +118 -131
- package/benchmarks/package-bench.mjs +294 -20
- package/dist/index.d.ts +4087 -41
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +8189 -40
- package/dist/index.js.map +1 -1
- package/package.json +4 -6
- package/benchmarks/package-bench-fixtures.mjs +0 -95
- package/benchmarks/package-bench-rows.mjs +0 -211
- package/benchmarks/package-bench-runtime.mjs +0 -94
- package/dist/adaptive-load-decisions.d.ts +0 -8
- package/dist/adaptive-load-decisions.d.ts.map +0 -1
- package/dist/adaptive-load-decisions.js +0 -133
- package/dist/adaptive-load-decisions.js.map +0 -1
- package/dist/adaptive-load-limits.d.ts +0 -8
- package/dist/adaptive-load-limits.d.ts.map +0 -1
- package/dist/adaptive-load-limits.js +0 -105
- package/dist/adaptive-load-limits.js.map +0 -1
- package/dist/adaptive-load-observations.d.ts +0 -17
- package/dist/adaptive-load-observations.d.ts.map +0 -1
- package/dist/adaptive-load-observations.js +0 -295
- package/dist/adaptive-load-observations.js.map +0 -1
- package/dist/adaptive-load-types.d.ts +0 -117
- package/dist/adaptive-load-types.d.ts.map +0 -1
- package/dist/adaptive-load-types.js +0 -3
- package/dist/adaptive-load-types.js.map +0 -1
- package/dist/adaptive-load.d.ts +0 -10
- package/dist/adaptive-load.d.ts.map +0 -1
- package/dist/adaptive-load.js +0 -98
- package/dist/adaptive-load.js.map +0 -1
- package/dist/adaptive-types.d.ts +0 -127
- package/dist/adaptive-types.d.ts.map +0 -1
- package/dist/adaptive-types.js +0 -2
- package/dist/adaptive-types.js.map +0 -1
- package/dist/artifact-routing-runtime.d.ts +0 -3
- package/dist/artifact-routing-runtime.d.ts.map +0 -1
- package/dist/artifact-routing-runtime.js +0 -72
- package/dist/artifact-routing-runtime.js.map +0 -1
- package/dist/auto-review.d.ts +0 -47
- package/dist/auto-review.d.ts.map +0 -1
- package/dist/auto-review.js +0 -69
- package/dist/auto-review.js.map +0 -1
- package/dist/blackboard.d.ts +0 -81
- package/dist/blackboard.d.ts.map +0 -1
- package/dist/blackboard.js +0 -60
- package/dist/blackboard.js.map +0 -1
- package/dist/coercion.d.ts +0 -12
- package/dist/coercion.d.ts.map +0 -1
- package/dist/coercion.js +0 -48
- package/dist/coercion.js.map +0 -1
- package/dist/constants.d.ts +0 -106
- package/dist/constants.d.ts.map +0 -1
- package/dist/constants.js +0 -106
- package/dist/constants.js.map +0 -1
- package/dist/context-pack-runtime.d.ts +0 -3
- package/dist/context-pack-runtime.d.ts.map +0 -1
- package/dist/context-pack-runtime.js +0 -77
- package/dist/context-pack-runtime.js.map +0 -1
- package/dist/context-types.d.ts +0 -188
- package/dist/context-types.d.ts.map +0 -1
- package/dist/context-types.js +0 -2
- package/dist/context-types.js.map +0 -1
- package/dist/coordinator-dashboard-helpers.d.ts +0 -14
- package/dist/coordinator-dashboard-helpers.d.ts.map +0 -1
- package/dist/coordinator-dashboard-helpers.js +0 -106
- package/dist/coordinator-dashboard-helpers.js.map +0 -1
- package/dist/coordinator-dashboard-types.d.ts +0 -163
- package/dist/coordinator-dashboard-types.d.ts.map +0 -1
- package/dist/coordinator-dashboard-types.js +0 -3
- package/dist/coordinator-dashboard-types.js.map +0 -1
- package/dist/coordinator-dashboard.d.ts +0 -4
- package/dist/coordinator-dashboard.d.ts.map +0 -1
- package/dist/coordinator-dashboard.js +0 -163
- package/dist/coordinator-dashboard.js.map +0 -1
- package/dist/coordinator-scoring.d.ts +0 -8
- package/dist/coordinator-scoring.d.ts.map +0 -1
- package/dist/coordinator-scoring.js +0 -167
- package/dist/coordinator-scoring.js.map +0 -1
- package/dist/coordinator-types.d.ts +0 -166
- package/dist/coordinator-types.d.ts.map +0 -1
- package/dist/coordinator-types.js +0 -2
- package/dist/coordinator-types.js.map +0 -1
- package/dist/debug-runtime.d.ts +0 -4
- package/dist/debug-runtime.d.ts.map +0 -1
- package/dist/debug-runtime.js +0 -93
- package/dist/debug-runtime.js.map +0 -1
- package/dist/debug-types.d.ts +0 -194
- package/dist/debug-types.d.ts.map +0 -1
- package/dist/debug-types.js +0 -2
- package/dist/debug-types.js.map +0 -1
- package/dist/diagnostic-helpers.d.ts +0 -5
- package/dist/diagnostic-helpers.d.ts.map +0 -1
- package/dist/diagnostic-helpers.js +0 -54
- package/dist/diagnostic-helpers.js.map +0 -1
- package/dist/evidence-index-helpers.d.ts +0 -10
- package/dist/evidence-index-helpers.d.ts.map +0 -1
- package/dist/evidence-index-helpers.js +0 -78
- package/dist/evidence-index-helpers.js.map +0 -1
- package/dist/evidence-index.d.ts +0 -4
- package/dist/evidence-index.d.ts.map +0 -1
- package/dist/evidence-index.js +0 -59
- package/dist/evidence-index.js.map +0 -1
- package/dist/evidence-types.d.ts +0 -151
- package/dist/evidence-types.d.ts.map +0 -1
- package/dist/evidence-types.js +0 -2
- package/dist/evidence-types.js.map +0 -1
- package/dist/fixtures.d.ts +0 -45
- package/dist/fixtures.d.ts.map +0 -1
- package/dist/fixtures.js +0 -39
- package/dist/fixtures.js.map +0 -1
- package/dist/governance-types.d.ts +0 -172
- package/dist/governance-types.d.ts.map +0 -1
- package/dist/governance-types.js +0 -2
- package/dist/governance-types.js.map +0 -1
- package/dist/instrumentation-runtime.d.ts +0 -6
- package/dist/instrumentation-runtime.d.ts.map +0 -1
- package/dist/instrumentation-runtime.js +0 -111
- package/dist/instrumentation-runtime.js.map +0 -1
- package/dist/internal.d.ts +0 -11
- package/dist/internal.d.ts.map +0 -1
- package/dist/internal.js +0 -49
- package/dist/internal.js.map +0 -1
- package/dist/leases.d.ts +0 -32
- package/dist/leases.d.ts.map +0 -1
- package/dist/leases.js +0 -36
- package/dist/leases.js.map +0 -1
- package/dist/manifest-normalization.d.ts +0 -8
- package/dist/manifest-normalization.d.ts.map +0 -1
- package/dist/manifest-normalization.js +0 -191
- package/dist/manifest-normalization.js.map +0 -1
- package/dist/manifest-types.d.ts +0 -227
- package/dist/manifest-types.d.ts.map +0 -1
- package/dist/manifest-types.js +0 -2
- package/dist/manifest-types.js.map +0 -1
- package/dist/manifest.d.ts +0 -7
- package/dist/manifest.d.ts.map +0 -1
- package/dist/manifest.js +0 -126
- package/dist/manifest.js.map +0 -1
- package/dist/merge-admission.d.ts +0 -3
- package/dist/merge-admission.d.ts.map +0 -1
- package/dist/merge-admission.js +0 -71
- package/dist/merge-admission.js.map +0 -1
- package/dist/merge-bundles.d.ts +0 -13
- package/dist/merge-bundles.d.ts.map +0 -1
- package/dist/merge-bundles.js +0 -144
- package/dist/merge-bundles.js.map +0 -1
- package/dist/merge-classification.d.ts +0 -6
- package/dist/merge-classification.d.ts.map +0 -1
- package/dist/merge-classification.js +0 -36
- package/dist/merge-classification.js.map +0 -1
- package/dist/merge-index.d.ts +0 -3
- package/dist/merge-index.d.ts.map +0 -1
- package/dist/merge-index.js +0 -130
- package/dist/merge-index.js.map +0 -1
- package/dist/merge-plan-helpers.d.ts +0 -11
- package/dist/merge-plan-helpers.d.ts.map +0 -1
- package/dist/merge-plan-helpers.js +0 -97
- package/dist/merge-plan-helpers.js.map +0 -1
- package/dist/merge-plans-runtime.d.ts +0 -8
- package/dist/merge-plans-runtime.d.ts.map +0 -1
- package/dist/merge-plans-runtime.js +0 -106
- package/dist/merge-plans-runtime.js.map +0 -1
- package/dist/merge-review-types.d.ts +0 -76
- package/dist/merge-review-types.d.ts.map +0 -1
- package/dist/merge-review-types.js +0 -2
- package/dist/merge-review-types.js.map +0 -1
- package/dist/merge-review.d.ts +0 -7
- package/dist/merge-review.d.ts.map +0 -1
- package/dist/merge-review.js +0 -142
- package/dist/merge-review.js.map +0 -1
- package/dist/merge-types.d.ts +0 -196
- package/dist/merge-types.d.ts.map +0 -1
- package/dist/merge-types.js +0 -2
- package/dist/merge-types.js.map +0 -1
- package/dist/merge-wrappers.d.ts +0 -5
- package/dist/merge-wrappers.d.ts.map +0 -1
- package/dist/merge-wrappers.js +0 -231
- package/dist/merge-wrappers.js.map +0 -1
- package/dist/observability-types.d.ts +0 -164
- package/dist/observability-types.d.ts.map +0 -1
- package/dist/observability-types.js +0 -2
- package/dist/observability-types.js.map +0 -1
- package/dist/oracle-helpers.d.ts +0 -6
- package/dist/oracle-helpers.d.ts.map +0 -1
- package/dist/oracle-helpers.js +0 -73
- package/dist/oracle-helpers.js.map +0 -1
- package/dist/oracle-runtime.d.ts +0 -5
- package/dist/oracle-runtime.d.ts.map +0 -1
- package/dist/oracle-runtime.js +0 -154
- package/dist/oracle-runtime.js.map +0 -1
- package/dist/ownership-runtime.d.ts +0 -6
- package/dist/ownership-runtime.d.ts.map +0 -1
- package/dist/ownership-runtime.js +0 -49
- package/dist/ownership-runtime.js.map +0 -1
- package/dist/patch-stack-runtime.d.ts +0 -4
- package/dist/patch-stack-runtime.d.ts.map +0 -1
- package/dist/patch-stack-runtime.js +0 -97
- package/dist/patch-stack-runtime.js.map +0 -1
- package/dist/plan-helpers.d.ts +0 -13
- package/dist/plan-helpers.d.ts.map +0 -1
- package/dist/plan-helpers.js +0 -236
- package/dist/plan-helpers.js.map +0 -1
- package/dist/plan-selection.d.ts +0 -7
- package/dist/plan-selection.d.ts.map +0 -1
- package/dist/plan-selection.js +0 -86
- package/dist/plan-selection.js.map +0 -1
- package/dist/plan.d.ts +0 -126
- package/dist/plan.d.ts.map +0 -1
- package/dist/plan.js +0 -67
- package/dist/plan.js.map +0 -1
- package/dist/progress.d.ts +0 -42
- package/dist/progress.d.ts.map +0 -1
- package/dist/progress.js +0 -31
- package/dist/progress.js.map +0 -1
- package/dist/proof-runtime.d.ts +0 -16
- package/dist/proof-runtime.d.ts.map +0 -1
- package/dist/proof-runtime.js +0 -143
- package/dist/proof-runtime.js.map +0 -1
- package/dist/queue-overlays.d.ts +0 -7
- package/dist/queue-overlays.d.ts.map +0 -1
- package/dist/queue-overlays.js +0 -184
- package/dist/queue-overlays.js.map +0 -1
- package/dist/queue-types.d.ts +0 -194
- package/dist/queue-types.d.ts.map +0 -1
- package/dist/queue-types.js +0 -2
- package/dist/queue-types.js.map +0 -1
- package/dist/rebase-report.d.ts +0 -3
- package/dist/rebase-report.d.ts.map +0 -1
- package/dist/rebase-report.js +0 -52
- package/dist/rebase-report.js.map +0 -1
- package/dist/record-helpers.d.ts +0 -15
- package/dist/record-helpers.d.ts.map +0 -1
- package/dist/record-helpers.js +0 -78
- package/dist/record-helpers.js.map +0 -1
- package/dist/reference-oracle-runtime.d.ts +0 -4
- package/dist/reference-oracle-runtime.d.ts.map +0 -1
- package/dist/reference-oracle-runtime.js +0 -89
- package/dist/reference-oracle-runtime.js.map +0 -1
- package/dist/reference-types.d.ts +0 -204
- package/dist/reference-types.d.ts.map +0 -1
- package/dist/reference-types.js +0 -2
- package/dist/reference-types.js.map +0 -1
- package/dist/result-types.d.ts +0 -75
- package/dist/result-types.d.ts.map +0 -1
- package/dist/result-types.js +0 -2
- package/dist/result-types.js.map +0 -1
- package/dist/run-normalization.d.ts +0 -9
- package/dist/run-normalization.d.ts.map +0 -1
- package/dist/run-normalization.js +0 -126
- package/dist/run-normalization.js.map +0 -1
- package/dist/run-records.d.ts +0 -8
- package/dist/run-records.d.ts.map +0 -1
- package/dist/run-records.js +0 -145
- package/dist/run-records.js.map +0 -1
- package/dist/run-store-shards-runtime.d.ts +0 -3
- package/dist/run-store-shards-runtime.d.ts.map +0 -1
- package/dist/run-store-shards-runtime.js +0 -54
- package/dist/run-store-shards-runtime.js.map +0 -1
- package/dist/run-types.d.ts +0 -112
- package/dist/run-types.d.ts.map +0 -1
- package/dist/run-types.js +0 -2
- package/dist/run-types.js.map +0 -1
- package/dist/scheduler.d.ts +0 -94
- package/dist/scheduler.d.ts.map +0 -1
- package/dist/scheduler.js +0 -213
- package/dist/scheduler.js.map +0 -1
- package/dist/semantic-normalization.d.ts +0 -3
- package/dist/semantic-normalization.d.ts.map +0 -1
- package/dist/semantic-normalization.js +0 -195
- package/dist/semantic-normalization.js.map +0 -1
- package/dist/semantic-types.d.ts +0 -265
- package/dist/semantic-types.d.ts.map +0 -1
- package/dist/semantic-types.js +0 -2
- package/dist/semantic-types.js.map +0 -1
- package/dist/status-types.d.ts +0 -28
- package/dist/status-types.d.ts.map +0 -1
- package/dist/status-types.js +0 -2
- package/dist/status-types.js.map +0 -1
- package/dist/task-types.d.ts +0 -165
- package/dist/task-types.d.ts.map +0 -1
- package/dist/task-types.js +0 -2
- package/dist/task-types.js.map +0 -1
- package/dist/tournament-adaptive-feedback.d.ts +0 -22
- package/dist/tournament-adaptive-feedback.d.ts.map +0 -1
- package/dist/tournament-adaptive-feedback.js +0 -240
- package/dist/tournament-adaptive-feedback.js.map +0 -1
- package/dist/tournament-bandit-types.d.ts +0 -91
- package/dist/tournament-bandit-types.d.ts.map +0 -1
- package/dist/tournament-bandit-types.js +0 -2
- package/dist/tournament-bandit-types.js.map +0 -1
- package/dist/tournament-bandit.d.ts +0 -4
- package/dist/tournament-bandit.d.ts.map +0 -1
- package/dist/tournament-bandit.js +0 -212
- package/dist/tournament-bandit.js.map +0 -1
- package/dist/tournament-history-types.d.ts +0 -138
- package/dist/tournament-history-types.d.ts.map +0 -1
- package/dist/tournament-history-types.js +0 -2
- package/dist/tournament-history-types.js.map +0 -1
- package/dist/tournament-history.d.ts +0 -5
- package/dist/tournament-history.d.ts.map +0 -1
- package/dist/tournament-history.js +0 -210
- package/dist/tournament-history.js.map +0 -1
- package/dist/tournament-merge.d.ts +0 -7
- package/dist/tournament-merge.d.ts.map +0 -1
- package/dist/tournament-merge.js +0 -172
- package/dist/tournament-merge.js.map +0 -1
- package/dist/tournament-runtime-helpers.d.ts +0 -9
- package/dist/tournament-runtime-helpers.d.ts.map +0 -1
- package/dist/tournament-runtime-helpers.js +0 -114
- package/dist/tournament-runtime-helpers.js.map +0 -1
- package/dist/tournament-runtime.d.ts +0 -6
- package/dist/tournament-runtime.d.ts.map +0 -1
- package/dist/tournament-runtime.js +0 -202
- package/dist/tournament-runtime.js.map +0 -1
- package/dist/tournament-sample-observations.d.ts +0 -4
- package/dist/tournament-sample-observations.d.ts.map +0 -1
- package/dist/tournament-sample-observations.js +0 -19
- package/dist/tournament-sample-observations.js.map +0 -1
- package/dist/tournament-sample-quality-types.d.ts +0 -17
- package/dist/tournament-sample-quality-types.d.ts.map +0 -1
- package/dist/tournament-sample-quality-types.js +0 -2
- package/dist/tournament-sample-quality-types.js.map +0 -1
- package/dist/tournament-sample-quality.d.ts +0 -8
- package/dist/tournament-sample-quality.d.ts.map +0 -1
- package/dist/tournament-sample-quality.js +0 -66
- package/dist/tournament-sample-quality.js.map +0 -1
- package/dist/tournament-scoring.d.ts +0 -18
- package/dist/tournament-scoring.d.ts.map +0 -1
- package/dist/tournament-scoring.js +0 -136
- package/dist/tournament-scoring.js.map +0 -1
- package/dist/tournament-types.d.ts +0 -269
- package/dist/tournament-types.d.ts.map +0 -1
- package/dist/tournament-types.js +0 -2
- package/dist/tournament-types.js.map +0 -1
- package/dist/trace-helpers.d.ts +0 -22
- package/dist/trace-helpers.d.ts.map +0 -1
- package/dist/trace-helpers.js +0 -181
- package/dist/trace-helpers.js.map +0 -1
- package/dist/trace-runtime.d.ts +0 -7
- package/dist/trace-runtime.d.ts.map +0 -1
- package/dist/trace-runtime.js +0 -196
- package/dist/trace-runtime.js.map +0 -1
- package/dist/trace-types.d.ts +0 -168
- package/dist/trace-types.d.ts.map +0 -1
- package/dist/trace-types.js +0 -2
- package/dist/trace-types.js.map +0 -1
- package/dist/types.d.ts +0 -23
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
- package/dist/usage-governor.d.ts +0 -41
- package/dist/usage-governor.d.ts.map +0 -1
- package/dist/usage-governor.js +0 -43
- package/dist/usage-governor.js.map +0 -1
package/dist/oracle-runtime.js
DELETED
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
import { FRONTIER_SWARM_ORACLE_CORPUS_KIND, FRONTIER_SWARM_ORACLE_CORPUS_VERSION, FRONTIER_SWARM_PARITY_ORACLE_KIND, FRONTIER_SWARM_PARITY_ORACLE_VERSION, FRONTIER_SWARM_REPLAY_BUNDLE_KIND, FRONTIER_SWARM_REPLAY_BUNDLE_VERSION } from './constants.js';
|
|
2
|
-
import { inferParityStatus, normalizeParityComparator, normalizeSeedRefs } from './oracle-helpers.js';
|
|
3
|
-
import { positiveNumber, stableHash, toJsonObject, uniqueStrings } from './internal.js';
|
|
4
|
-
export function createSwarmOracleCorpus(input = {}) {
|
|
5
|
-
const generatedAt = input.generatedAt ?? Date.now();
|
|
6
|
-
const artifacts = (input.artifacts ?? []).map(normalizeOracleArtifact).sort((left, right) => left.id.localeCompare(right.id));
|
|
7
|
-
const byKind = groupArtifactIdsBy(artifacts, (artifact) => [artifact.kind]);
|
|
8
|
-
const byTag = groupArtifactIdsBy(artifacts, (artifact) => artifact.tags);
|
|
9
|
-
return {
|
|
10
|
-
kind: FRONTIER_SWARM_ORACLE_CORPUS_KIND,
|
|
11
|
-
version: FRONTIER_SWARM_ORACLE_CORPUS_VERSION,
|
|
12
|
-
id: input.id ?? 'swarm-oracle-corpus:' + stableHash([artifacts, generatedAt]),
|
|
13
|
-
title: input.title ?? titleFromId(input.id ?? 'oracle corpus'),
|
|
14
|
-
generatedAt,
|
|
15
|
-
artifacts,
|
|
16
|
-
byKind,
|
|
17
|
-
byTag,
|
|
18
|
-
summary: {
|
|
19
|
-
artifactCount: artifacts.length,
|
|
20
|
-
kindCount: Object.keys(byKind).length,
|
|
21
|
-
tagCount: Object.keys(byTag).length
|
|
22
|
-
},
|
|
23
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
export function createSwarmReplayBundle(input = {}) {
|
|
27
|
-
const generatedAt = input.generatedAt ?? Date.now();
|
|
28
|
-
const commands = normalizeCommands(input.commands ?? []);
|
|
29
|
-
const inputs = normalizeNamedRefs(input.inputs ?? [], 'input');
|
|
30
|
-
const artifacts = normalizeNamedRefs(input.artifacts ?? [], 'artifact');
|
|
31
|
-
const sourceRefs = normalizeNamedRefs(input.sourceRefs ?? [], 'source');
|
|
32
|
-
const seeds = normalizeSeedRefs(input.seeds ?? []);
|
|
33
|
-
const expectedEvidence = uniqueStrings(input.expectedEvidence ?? []);
|
|
34
|
-
const title = input.title ?? titleFromId(input.id ?? input.subject ?? 'replay bundle');
|
|
35
|
-
return {
|
|
36
|
-
kind: FRONTIER_SWARM_REPLAY_BUNDLE_KIND,
|
|
37
|
-
version: FRONTIER_SWARM_REPLAY_BUNDLE_VERSION,
|
|
38
|
-
id: input.id ?? 'swarm-replay-bundle:' + stableHash([title, input.subject, commands, inputs, artifacts, sourceRefs, seeds, expectedEvidence, generatedAt]),
|
|
39
|
-
title,
|
|
40
|
-
...(input.subject ? { subject: input.subject } : {}),
|
|
41
|
-
generatedAt,
|
|
42
|
-
commands,
|
|
43
|
-
inputs,
|
|
44
|
-
artifacts,
|
|
45
|
-
sourceRefs,
|
|
46
|
-
seeds,
|
|
47
|
-
...(toJsonObject(input.environment) ? { environment: toJsonObject(input.environment) } : {}),
|
|
48
|
-
expectedEvidence,
|
|
49
|
-
summary: {
|
|
50
|
-
commandCount: commands.length,
|
|
51
|
-
inputCount: inputs.length,
|
|
52
|
-
artifactCount: artifacts.length,
|
|
53
|
-
sourceRefCount: sourceRefs.length
|
|
54
|
-
},
|
|
55
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
export function createSwarmParityOracle(input = {}) {
|
|
59
|
-
const generatedAt = input.generatedAt ?? Date.now();
|
|
60
|
-
const referenceCommands = normalizeCommands(input.referenceCommands ?? []);
|
|
61
|
-
const testCommands = normalizeCommands(input.testCommands ?? []);
|
|
62
|
-
const comparators = (input.comparators ?? []).map(normalizeParityComparator);
|
|
63
|
-
const artifacts = normalizeNamedRefs(input.artifacts ?? [], 'parity-artifact');
|
|
64
|
-
const status = input.status ?? inferParityStatus(comparators);
|
|
65
|
-
return {
|
|
66
|
-
kind: FRONTIER_SWARM_PARITY_ORACLE_KIND,
|
|
67
|
-
version: FRONTIER_SWARM_PARITY_ORACLE_VERSION,
|
|
68
|
-
id: input.id ?? 'swarm-parity-oracle:' + stableHash([input.title, input.subject, referenceCommands, testCommands, comparators, artifacts, generatedAt]),
|
|
69
|
-
title: input.title ?? titleFromId(input.id ?? input.subject ?? 'parity oracle'),
|
|
70
|
-
status,
|
|
71
|
-
...(input.subject ? { subject: input.subject } : {}),
|
|
72
|
-
generatedAt,
|
|
73
|
-
referenceCommands,
|
|
74
|
-
testCommands,
|
|
75
|
-
comparators,
|
|
76
|
-
artifacts,
|
|
77
|
-
replayBundleIds: uniqueStrings(input.replayBundleIds ?? []),
|
|
78
|
-
summary: {
|
|
79
|
-
comparatorCount: comparators.length,
|
|
80
|
-
passedCount: comparators.filter((comparator) => comparator.status === 'passed').length,
|
|
81
|
-
failedCount: comparators.filter((comparator) => comparator.status === 'failed').length,
|
|
82
|
-
blockedCount: comparators.filter((comparator) => comparator.status === 'blocked').length
|
|
83
|
-
},
|
|
84
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
function normalizeOracleArtifact(input) {
|
|
88
|
-
return {
|
|
89
|
-
id: normalizeId(input.id, 'oracle artifact id'),
|
|
90
|
-
path: normalizeId(input.path, 'oracle artifact path'),
|
|
91
|
-
kind: input.kind ?? 'oracle',
|
|
92
|
-
...(input.command ? { command: typeof input.command === 'string' ? normalizeCommands([input.command])[0] : normalizeCommands([input.command])[0] } : {}),
|
|
93
|
-
...(input.hash ? { hash: input.hash } : {}),
|
|
94
|
-
...(input.sourceRef ? { sourceRef: input.sourceRef } : {}),
|
|
95
|
-
tags: uniqueStrings(input.tags ?? []),
|
|
96
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
function groupArtifactIdsBy(artifacts, key) {
|
|
100
|
-
const out = {};
|
|
101
|
-
for (const artifact of artifacts) {
|
|
102
|
-
for (const value of key(artifact))
|
|
103
|
-
out[value] = uniqueStrings([...(out[value] ?? []), artifact.id]);
|
|
104
|
-
}
|
|
105
|
-
return out;
|
|
106
|
-
}
|
|
107
|
-
function titleFromId(id) {
|
|
108
|
-
const parts = String(id).split(/[.:/_-]+/).filter(Boolean);
|
|
109
|
-
return parts.length ? parts.map((part) => part[0]?.toUpperCase() + part.slice(1)).join(' ') : String(id);
|
|
110
|
-
}
|
|
111
|
-
function normalizeCommands(input) {
|
|
112
|
-
return input.map((entry) => {
|
|
113
|
-
if (typeof entry === 'string') {
|
|
114
|
-
return { name: entry, command: entry, args: [], required: true };
|
|
115
|
-
}
|
|
116
|
-
return {
|
|
117
|
-
name: entry.name ?? [entry.command, ...(entry.args ?? [])].join(' '),
|
|
118
|
-
command: entry.command,
|
|
119
|
-
args: [...(entry.args ?? [])],
|
|
120
|
-
required: entry.required ?? true,
|
|
121
|
-
...(entry.cwd ? { cwd: entry.cwd } : {}),
|
|
122
|
-
...(toJsonObject(entry.metadata) ? { metadata: toJsonObject(entry.metadata) } : {})
|
|
123
|
-
};
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
function normalizeNamedRefs(input, fallbackKind) {
|
|
127
|
-
return input.map((entry) => normalizeNamedRef(entry, fallbackKind)).sort((left, right) => left.id.localeCompare(right.id));
|
|
128
|
-
}
|
|
129
|
-
function normalizeId(value, label) {
|
|
130
|
-
const id = String(value || '').trim();
|
|
131
|
-
if (!id)
|
|
132
|
-
throw new Error(`Missing ${label}`);
|
|
133
|
-
return id;
|
|
134
|
-
}
|
|
135
|
-
function normalizeNamedRef(input, fallbackKind) {
|
|
136
|
-
if (typeof input === 'string' || typeof input === 'number') {
|
|
137
|
-
const value = String(input);
|
|
138
|
-
return { id: value, kind: fallbackKind, path: value, tags: [] };
|
|
139
|
-
}
|
|
140
|
-
const path = input.path ?? input.uri;
|
|
141
|
-
const id = input.id ?? path ?? stableHash(input);
|
|
142
|
-
return {
|
|
143
|
-
id,
|
|
144
|
-
kind: input.kind ?? fallbackKind,
|
|
145
|
-
...(input.path ? { path: input.path } : {}),
|
|
146
|
-
...(input.uri ? { uri: input.uri } : {}),
|
|
147
|
-
...(input.role ? { role: input.role } : {}),
|
|
148
|
-
...(input.hash ? { hash: input.hash } : {}),
|
|
149
|
-
...(positiveNumber(input.bytes) ? { bytes: Math.floor(input.bytes) } : {}),
|
|
150
|
-
tags: uniqueStrings(input.tags ?? []),
|
|
151
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
152
|
-
};
|
|
153
|
-
}
|
|
154
|
-
//# sourceMappingURL=oracle-runtime.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"oracle-runtime.js","sourceRoot":"","sources":["../src/oracle-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { FrontierSwarmOwnershipReport, FrontierSwarmRegionOwnershipInput, FrontierSwarmRegionOwnershipReport } from './types.js';
|
|
2
|
-
import type { FrontierSwarmJob } from './plan.js';
|
|
3
|
-
export declare function checkSwarmOwnership(job: FrontierSwarmJob, changedPaths: readonly string[]): FrontierSwarmOwnershipReport;
|
|
4
|
-
export declare function resolveSwarmChangedRegions(job: FrontierSwarmJob, changedPaths: readonly string[]): string[];
|
|
5
|
-
export declare function checkSwarmRegionOwnership(job: FrontierSwarmJob, input?: FrontierSwarmRegionOwnershipInput): FrontierSwarmRegionOwnershipReport;
|
|
6
|
-
//# sourceMappingURL=ownership-runtime.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ownership-runtime.d.ts","sourceRoot":"","sources":["../src/ownership-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,4BAA4B,EAC5B,iCAAiC,EACjC,kCAAkC,EACnC,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAGlD,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,gBAAgB,EAAE,YAAY,EAAE,SAAS,MAAM,EAAE,GAAG,4BAA4B,CASxH;AAED,wBAAgB,0BAA0B,CAAC,GAAG,EAAE,gBAAgB,EAAE,YAAY,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,EAAE,CAU3G;AAED,wBAAgB,yBAAyB,CAAC,GAAG,EAAE,gBAAgB,EAAE,KAAK,GAAE,iCAAsC,GAAG,kCAAkC,CAsBlJ"}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { matchesGlob, uniqueStrings } from './internal.js';
|
|
2
|
-
export function checkSwarmOwnership(job, changedPaths) {
|
|
3
|
-
const changed = uniqueStrings(changedPaths);
|
|
4
|
-
const violations = changed.filter((file) => !job.allowedWrites.some((glob) => matchesGlob(file, glob)));
|
|
5
|
-
return {
|
|
6
|
-
ok: violations.length === 0,
|
|
7
|
-
changedPaths: changed,
|
|
8
|
-
allowedWrites: [...job.allowedWrites],
|
|
9
|
-
violations
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
export function resolveSwarmChangedRegions(job, changedPaths) {
|
|
13
|
-
const changed = uniqueStrings(changedPaths);
|
|
14
|
-
const regions = new Set(job.changedRegions);
|
|
15
|
-
for (const region of job.ownershipRegions) {
|
|
16
|
-
if (region.globs.some((glob) => changed.some((file) => matchesGlob(file, glob))))
|
|
17
|
-
regions.add(region.id);
|
|
18
|
-
for (const selector of region.selectors) {
|
|
19
|
-
if (changed.includes(selector))
|
|
20
|
-
regions.add(region.id);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
return Array.from(regions).sort();
|
|
24
|
-
}
|
|
25
|
-
export function checkSwarmRegionOwnership(job, input = {}) {
|
|
26
|
-
const changedPaths = uniqueStrings(input.changedPaths ?? []);
|
|
27
|
-
const resolvedRegions = resolveSwarmChangedRegions(job, changedPaths);
|
|
28
|
-
const changedRegions = uniqueStrings([...(input.changedRegions ?? []), ...resolvedRegions]);
|
|
29
|
-
const ownedRegions = new Set(job.ownedRegions);
|
|
30
|
-
const regionViolations = changedRegions.filter((region) => !ownedRegions.has(region));
|
|
31
|
-
const classifiedPaths = new Set();
|
|
32
|
-
for (const region of job.ownershipRegions) {
|
|
33
|
-
for (const file of changedPaths) {
|
|
34
|
-
if (region.globs.some((glob) => matchesGlob(file, glob)))
|
|
35
|
-
classifiedPaths.add(file);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
const unclassifiedChangedPaths = changedPaths.filter((file) => !classifiedPaths.has(file));
|
|
39
|
-
return {
|
|
40
|
-
ok: regionViolations.length === 0 && (job.ownershipRegions.length === 0 || unclassifiedChangedPaths.length === 0),
|
|
41
|
-
jobId: job.id,
|
|
42
|
-
changedPaths,
|
|
43
|
-
changedRegions,
|
|
44
|
-
ownedRegions: [...job.ownedRegions],
|
|
45
|
-
regionViolations,
|
|
46
|
-
unclassifiedChangedPaths
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
//# sourceMappingURL=ownership-runtime.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ownership-runtime.js","sourceRoot":"","sources":["../src/ownership-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { FrontierSwarmLanePlaybook, FrontierSwarmLanePlaybookInput, FrontierSwarmPatchStackPlan, FrontierSwarmPatchStackPlanInput } from './types.js';
|
|
2
|
-
export declare function createSwarmLanePlaybook(input: FrontierSwarmLanePlaybookInput): FrontierSwarmLanePlaybook;
|
|
3
|
-
export declare function createSwarmPatchStackPlan(input: FrontierSwarmPatchStackPlanInput): FrontierSwarmPatchStackPlan;
|
|
4
|
-
//# sourceMappingURL=patch-stack-runtime.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"patch-stack-runtime.d.ts","sourceRoot":"","sources":["../src/patch-stack-runtime.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAmD,yBAAyB,EAAE,8BAA8B,EAAyD,2BAA2B,EAAE,gCAAgC,EAAE,MAAM,YAAY,CAAC;AAEnQ,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,8BAA8B,GAAG,yBAAyB,CAsBxG;AACD,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,gCAAgC,GAAG,2BAA2B,CA2C9G"}
|
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
import { createSwarmHotspotReport } from './merge-wrappers.js';
|
|
2
|
-
import { FRONTIER_SWARM_LANE_PLAYBOOK_KIND, FRONTIER_SWARM_LANE_PLAYBOOK_VERSION, FRONTIER_SWARM_PATCH_STACK_PLAN_KIND, FRONTIER_SWARM_PATCH_STACK_PLAN_VERSION } from './constants.js';
|
|
3
|
-
import { patchStackKey, riskRank } from './merge-plan-helpers.js';
|
|
4
|
-
import { stableHash, toJsonObject, uniqueStrings } from './internal.js';
|
|
5
|
-
export function createSwarmLanePlaybook(input) {
|
|
6
|
-
const generatedAt = input.generatedAt ?? Date.now();
|
|
7
|
-
const successful = (input.successfulBundles ?? []).filter((bundle) => bundle.status === 'completed' || bundle.status === 'verified' || bundle.autoMergeable);
|
|
8
|
-
const hotPaths = createSwarmHotspotReport({ bundles: successful, threshold: 2, generatedAt }).entries
|
|
9
|
-
.filter((entry) => entry.touchCount >= 2)
|
|
10
|
-
.map((entry) => entry.path);
|
|
11
|
-
return {
|
|
12
|
-
kind: FRONTIER_SWARM_LANE_PLAYBOOK_KIND,
|
|
13
|
-
version: FRONTIER_SWARM_LANE_PLAYBOOK_VERSION,
|
|
14
|
-
id: input.id ?? 'swarm-lane-playbook:' + stableHash([input.lane, successful.map((bundle) => bundle.jobId), input.notes, generatedAt]),
|
|
15
|
-
lane: normalizeId(input.lane, 'playbook lane'),
|
|
16
|
-
title: input.title ?? `${titleFromId(input.lane)} Playbook`,
|
|
17
|
-
generatedAt,
|
|
18
|
-
notes: uniqueStrings(input.notes ?? []),
|
|
19
|
-
commands: normalizeCommands(input.commands ?? []),
|
|
20
|
-
avoidInvestigating: uniqueStrings(input.avoidInvestigating ?? []),
|
|
21
|
-
evidencePatterns: uniqueStrings(input.evidencePatterns ?? successful.flatMap((bundle) => bundle.evidencePaths)),
|
|
22
|
-
successfulJobIds: uniqueStrings(successful.map((bundle) => bundle.jobId)),
|
|
23
|
-
hotPaths,
|
|
24
|
-
changedRegions: uniqueStrings(successful.flatMap((bundle) => bundle.changedRegions)),
|
|
25
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
export function createSwarmPatchStackPlan(input) {
|
|
29
|
-
const generatedAt = input.generatedAt ?? Date.now();
|
|
30
|
-
const maxStackSize = Math.max(1, Math.floor(input.maxStackSize ?? 8));
|
|
31
|
-
const groups = new Map();
|
|
32
|
-
for (const entry of input.index.entries) {
|
|
33
|
-
const key = patchStackKey(entry);
|
|
34
|
-
groups.set(key, [...(groups.get(key) ?? []), entry]);
|
|
35
|
-
}
|
|
36
|
-
const stacks = [];
|
|
37
|
-
for (const [key, entries] of Array.from(groups.entries()).sort((left, right) => left[0].localeCompare(right[0]))) {
|
|
38
|
-
const sorted = [...entries].sort((left, right) => riskRank(left.riskLevel) - riskRank(right.riskLevel) || left.jobId.localeCompare(right.jobId));
|
|
39
|
-
for (let index = 0; index < sorted.length; index += maxStackSize) {
|
|
40
|
-
const slice = sorted.slice(index, index + maxStackSize);
|
|
41
|
-
const jobIds = slice.map((entry) => entry.jobId);
|
|
42
|
-
const conflicts = input.index.conflicts.filter((conflict) => conflict.jobIds.some((jobId) => jobIds.includes(jobId)));
|
|
43
|
-
stacks.push({
|
|
44
|
-
id: 'swarm-patch-stack:' + stableHash([input.index.id, key, index, jobIds]),
|
|
45
|
-
title: titleFromId(key),
|
|
46
|
-
...(slice[0]?.lane ? { lane: slice[0].lane } : {}),
|
|
47
|
-
jobIds,
|
|
48
|
-
changedPaths: uniqueStrings(slice.flatMap((entry) => entry.changedPaths)),
|
|
49
|
-
changedRegions: uniqueStrings(slice.flatMap((entry) => entry.changedRegions)),
|
|
50
|
-
riskLevels: uniqueStrings(slice.map((entry) => entry.riskLevel)),
|
|
51
|
-
dispositions: uniqueStrings(slice.map((entry) => entry.disposition)),
|
|
52
|
-
conflicts,
|
|
53
|
-
gateHints: uniqueStrings(slice.flatMap((entry) => entry.evidencePaths.filter((file) => file.endsWith('.json') || file.endsWith('.jsonl'))))
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
return {
|
|
58
|
-
kind: FRONTIER_SWARM_PATCH_STACK_PLAN_KIND,
|
|
59
|
-
version: FRONTIER_SWARM_PATCH_STACK_PLAN_VERSION,
|
|
60
|
-
id: input.id ?? 'swarm-patch-stack-plan:' + stableHash([input.index.id, stacks, generatedAt]),
|
|
61
|
-
mergeIndexId: input.index.id,
|
|
62
|
-
generatedAt,
|
|
63
|
-
stacks,
|
|
64
|
-
summary: {
|
|
65
|
-
stackCount: stacks.length,
|
|
66
|
-
jobCount: input.index.entries.length,
|
|
67
|
-
conflictedStackCount: stacks.filter((stack) => stack.conflicts.length > 0).length
|
|
68
|
-
},
|
|
69
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
function normalizeId(value, label) {
|
|
73
|
-
const id = String(value || '').trim();
|
|
74
|
-
if (!id)
|
|
75
|
-
throw new Error(`Missing ${label}`);
|
|
76
|
-
return id;
|
|
77
|
-
}
|
|
78
|
-
function titleFromId(id) {
|
|
79
|
-
const parts = String(id).split(/[.:/_-]+/).filter(Boolean);
|
|
80
|
-
return parts.length ? parts.map((part) => part[0]?.toUpperCase() + part.slice(1)).join(' ') : String(id);
|
|
81
|
-
}
|
|
82
|
-
function normalizeCommands(input) {
|
|
83
|
-
return input.map((entry) => {
|
|
84
|
-
if (typeof entry === 'string') {
|
|
85
|
-
return { name: entry, command: entry, args: [], required: true };
|
|
86
|
-
}
|
|
87
|
-
return {
|
|
88
|
-
name: entry.name ?? [entry.command, ...(entry.args ?? [])].join(' '),
|
|
89
|
-
command: entry.command,
|
|
90
|
-
args: [...(entry.args ?? [])],
|
|
91
|
-
required: entry.required ?? true,
|
|
92
|
-
...(entry.cwd ? { cwd: entry.cwd } : {}),
|
|
93
|
-
...(toJsonObject(entry.metadata) ? { metadata: toJsonObject(entry.metadata) } : {})
|
|
94
|
-
};
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
//# sourceMappingURL=patch-stack-runtime.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"patch-stack-runtime.js","sourceRoot":"","sources":["../src/patch-stack-runtime.ts"],"names":[],"mappings":"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"}
|
package/dist/plan-helpers.d.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { FrontierSwarmCompiled, FrontierSwarmCompute, FrontierSwarmManifest, FrontierSwarmSummary, FrontierSwarmTask, FrontierSwarmTaskInput, FrontierSwarmTaskSetInput, FrontierSwarmValidation } from './index.js';
|
|
2
|
-
import type { FrontierSwarmJob, FrontierSwarmJobGraph, FrontierSwarmPlanFilter, FrontierSwarmPlanInput, FrontierSwarmScheduleLimits } from './plan.js';
|
|
3
|
-
type DefineSwarmTasks = (input: readonly FrontierSwarmTaskInput[] | FrontierSwarmTaskSetInput) => FrontierSwarmTask[];
|
|
4
|
-
export declare function normalizePlanTaskInput(input: FrontierSwarmTask | FrontierSwarmTaskInput, defineSwarmTasks: DefineSwarmTasks): FrontierSwarmTask;
|
|
5
|
-
export declare function normalizePlanTaskList(input: readonly FrontierSwarmTaskInput[] | FrontierSwarmTaskSetInput | readonly FrontierSwarmTask[], defineSwarmTasks: DefineSwarmTasks): FrontierSwarmTask[];
|
|
6
|
-
export declare function createPlanJob(compiled: FrontierSwarmCompiled, task: FrontierSwarmTask, options: FrontierSwarmPlanFilter): FrontierSwarmJob;
|
|
7
|
-
export declare function resolvePlanTaskCompute(compiled: FrontierSwarmCompiled, task: FrontierSwarmTask): FrontierSwarmCompute;
|
|
8
|
-
export declare function createPlanJobGraph(jobs: readonly FrontierSwarmJob[]): FrontierSwarmJobGraph;
|
|
9
|
-
export declare function normalizePlanScheduleLimits(manifest: FrontierSwarmManifest, options: FrontierSwarmPlanInput): FrontierSwarmScheduleLimits;
|
|
10
|
-
export declare function validatePlanTasksForManifest(compiled: FrontierSwarmCompiled, tasks: readonly FrontierSwarmTask[], graph?: FrontierSwarmJobGraph): FrontierSwarmValidation;
|
|
11
|
-
export declare function summarizePlanJobs(jobs: readonly FrontierSwarmJob[]): FrontierSwarmSummary;
|
|
12
|
-
export {};
|
|
13
|
-
//# sourceMappingURL=plan-helpers.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"plan-helpers.d.ts","sourceRoot":"","sources":["../src/plan-helpers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,qBAAqB,EACrB,oBAAoB,EAEpB,qBAAqB,EAKrB,oBAAoB,EACpB,iBAAiB,EACjB,sBAAsB,EACtB,yBAAyB,EACzB,uBAAuB,EAExB,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EACV,gBAAgB,EAChB,qBAAqB,EAErB,uBAAuB,EACvB,sBAAsB,EACtB,2BAA2B,EAC5B,MAAM,WAAW,CAAC;AAEnB,KAAK,gBAAgB,GAAG,CAAC,KAAK,EAAE,SAAS,sBAAsB,EAAE,GAAG,yBAAyB,KAAK,iBAAiB,EAAE,CAAC;AAEtH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,iBAAiB,GAAG,sBAAsB,EAAE,gBAAgB,EAAE,gBAAgB,GAAG,iBAAiB,CAE/I;AAED,wBAAgB,qBAAqB,CACnC,KAAK,EAAE,SAAS,sBAAsB,EAAE,GAAG,yBAAyB,GAAG,SAAS,iBAAiB,EAAE,EACnG,gBAAgB,EAAE,gBAAgB,GACjC,iBAAiB,EAAE,CAGrB;AAED,wBAAgB,aAAa,CAAC,QAAQ,EAAE,qBAAqB,EAAE,IAAI,EAAE,iBAAiB,EAAE,OAAO,EAAE,uBAAuB,GAAG,gBAAgB,CA2C1I;AAED,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,qBAAqB,EAAE,IAAI,EAAE,iBAAiB,GAAG,oBAAoB,CAOrH;AAED,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,SAAS,gBAAgB,EAAE,GAAG,qBAAqB,CA0C3F;AAED,wBAAgB,2BAA2B,CAAC,QAAQ,EAAE,qBAAqB,EAAE,OAAO,EAAE,sBAAsB,GAAG,2BAA2B,CAczI;AAED,wBAAgB,4BAA4B,CAAC,QAAQ,EAAE,qBAAqB,EAAE,KAAK,EAAE,SAAS,iBAAiB,EAAE,EAAE,KAAK,CAAC,EAAE,qBAAqB,GAAG,uBAAuB,CAazK;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,SAAS,gBAAgB,EAAE,GAAG,oBAAoB,CASzF"}
|
package/dist/plan-helpers.js
DELETED
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
import { cloneJsonValue, matchesGlob, positiveNumber, slug, toJsonObject, uniqueStrings } from './internal.js';
|
|
2
|
-
export function normalizePlanTaskInput(input, defineSwarmTasks) {
|
|
3
|
-
return isPlanSwarmTask(input) ? cloneJsonValue(input) : defineSwarmTasks([input])[0];
|
|
4
|
-
}
|
|
5
|
-
export function normalizePlanTaskList(input, defineSwarmTasks) {
|
|
6
|
-
if (Array.isArray(input))
|
|
7
|
-
return input.map((task) => normalizePlanTaskInput(task, defineSwarmTasks));
|
|
8
|
-
return defineSwarmTasks(input);
|
|
9
|
-
}
|
|
10
|
-
export function createPlanJob(compiled, task, options) {
|
|
11
|
-
const lane = task.lane ? compiled.lanesById.get(task.lane) : undefined;
|
|
12
|
-
const layer = task.layer ?? lane?.layer ?? compiled.manifest.policy.defaultLayer;
|
|
13
|
-
const compute = options.compute ? readCompute(compiled, options.compute) : resolvePlanTaskCompute(compiled, task);
|
|
14
|
-
const evidencePrefix = lane?.evidencePrefix ? lane.evidencePrefix.replace(/\/?$/, '/') + slug(task.id) + '/' : undefined;
|
|
15
|
-
const allowedWrites = uniqueStrings([...(lane?.allowedWrites ?? []), ...task.allowedWrites, ...(evidencePrefix ? [evidencePrefix + '**'] : [])]);
|
|
16
|
-
const ownershipWarnings = task.targetRefs
|
|
17
|
-
.filter((file) => allowedWrites.length > 0 && !allowedWrites.some((glob) => matchesGlob(file, glob)))
|
|
18
|
-
.map((file) => `${file} is outside allowed write globs for ${lane?.id ?? 'unassigned'}`);
|
|
19
|
-
const capabilities = uniqueStrings([...(lane?.capabilities ?? []), ...task.capabilities]);
|
|
20
|
-
const resourceRequirements = mergeResourceRequirements(lane?.resourceRequirements, task.resourceRequirements, capabilities);
|
|
21
|
-
const ownershipRegions = mergeOwnershipRegions(lane?.ownershipRegions ?? [], task.ownershipRegions);
|
|
22
|
-
const ownedRegions = uniqueStrings([...task.ownedRegions, ...ownershipRegions.map((region) => region.id)]);
|
|
23
|
-
return {
|
|
24
|
-
id: `${lane?.id ?? 'unassigned'}-${slug(task.id)}`,
|
|
25
|
-
taskId: task.id,
|
|
26
|
-
title: task.title,
|
|
27
|
-
lane: lane?.id ?? 'unassigned',
|
|
28
|
-
...(layer ? { layer } : {}),
|
|
29
|
-
compute,
|
|
30
|
-
status: 'planned',
|
|
31
|
-
priority: task.priority,
|
|
32
|
-
task,
|
|
33
|
-
allowedWrites,
|
|
34
|
-
sharedReadOnly: uniqueStrings([...(compiled.manifest.policy.sharedReadOnly ?? []), ...(lane?.sharedReadOnly ?? [])]),
|
|
35
|
-
neverEdit: uniqueStrings([...(compiled.manifest.policy.neverEditWithoutParent ?? []), ...(lane?.neverEdit ?? [])]),
|
|
36
|
-
ownershipRegions,
|
|
37
|
-
ownedRegions,
|
|
38
|
-
changedRegions: uniqueStrings(task.changedRegions),
|
|
39
|
-
capabilities,
|
|
40
|
-
...(resourceRequirements ? { resourceRequirements } : {}),
|
|
41
|
-
...(lane?.worktreePath ? { worktreePath: lane.worktreePath } : {}),
|
|
42
|
-
...(evidencePrefix ? { evidencePrefix } : {}),
|
|
43
|
-
concurrencyKey: task.concurrencyKey ?? lane?.concurrencyKey ?? task.lane ?? compute.id,
|
|
44
|
-
ownershipWarnings,
|
|
45
|
-
verification: task.verification.length ? task.verification : (lane?.handoffCommands ?? []),
|
|
46
|
-
acceptance: [...task.acceptance],
|
|
47
|
-
dependsOn: resolveJobDependencies(task),
|
|
48
|
-
...(task.budget ? { budget: task.budget } : {}),
|
|
49
|
-
review: task.review ?? normalizeReviewPolicy(),
|
|
50
|
-
tags: uniqueStrings([...task.tags, ...(lane?.tags ?? []), ...(layer ? [layer] : []), compute.id]),
|
|
51
|
-
...(task.metadata ? { metadata: task.metadata } : {})
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
export function resolvePlanTaskCompute(compiled, task) {
|
|
55
|
-
if (task.compute)
|
|
56
|
-
return readCompute(compiled, task.compute);
|
|
57
|
-
const lane = task.lane ? compiled.lanesById.get(task.lane) : undefined;
|
|
58
|
-
if (lane?.compute)
|
|
59
|
-
return readCompute(compiled, lane.compute);
|
|
60
|
-
const layerId = task.layer ?? lane?.layer ?? compiled.manifest.policy.defaultLayer;
|
|
61
|
-
const layered = layerId ? resolveLayerCompute(compiled, layerId) : undefined;
|
|
62
|
-
return layered ?? readCompute(compiled, compiled.manifest.policy.defaultCompute);
|
|
63
|
-
}
|
|
64
|
-
export function createPlanJobGraph(jobs) {
|
|
65
|
-
const nodes = jobs.map((job) => job.id).sort();
|
|
66
|
-
const nodeSet = new Set(nodes);
|
|
67
|
-
const taskToJob = new Map(jobs.map((job) => [job.taskId, job.id]));
|
|
68
|
-
const edges = [];
|
|
69
|
-
const issues = [];
|
|
70
|
-
for (const job of jobs) {
|
|
71
|
-
for (const rawDep of job.dependsOn) {
|
|
72
|
-
const dep = nodeSet.has(rawDep) ? rawDep : taskToJob.get(rawDep);
|
|
73
|
-
if (!dep) {
|
|
74
|
-
addIssue(issues, 'missing-job-dependency', 'error', `jobs.${job.id}.dependsOn`, `Job dependency is not in this plan: ${rawDep}`);
|
|
75
|
-
continue;
|
|
76
|
-
}
|
|
77
|
-
if (dep === job.id) {
|
|
78
|
-
addIssue(issues, 'self-job-dependency', 'error', `jobs.${job.id}.dependsOn`, `Job cannot depend on itself: ${job.id}`);
|
|
79
|
-
continue;
|
|
80
|
-
}
|
|
81
|
-
edges.push({ from: dep, to: job.id, type: 'depends-on' });
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const dependenciesByJobId = Object.fromEntries(nodes.map((node) => [node, []]));
|
|
85
|
-
const dependentsByJobId = Object.fromEntries(nodes.map((node) => [node, []]));
|
|
86
|
-
for (const edge of edges) {
|
|
87
|
-
dependenciesByJobId[edge.to]?.push(edge.from);
|
|
88
|
-
dependentsByJobId[edge.from]?.push(edge.to);
|
|
89
|
-
}
|
|
90
|
-
for (const key of nodes) {
|
|
91
|
-
dependenciesByJobId[key] = uniqueStrings(dependenciesByJobId[key] ?? []).sort();
|
|
92
|
-
dependentsByJobId[key] = uniqueStrings(dependentsByJobId[key] ?? []).sort();
|
|
93
|
-
if (hasJobDependencyCycle(key, dependenciesByJobId)) {
|
|
94
|
-
addIssue(issues, 'job-dependency-cycle', 'error', `jobs.${key}.dependsOn`, `Job dependency graph contains a cycle at ${key}`);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
return {
|
|
98
|
-
nodes,
|
|
99
|
-
edges: edges.sort((left, right) => left.from.localeCompare(right.from) || left.to.localeCompare(right.to)),
|
|
100
|
-
dependentsByJobId,
|
|
101
|
-
dependenciesByJobId,
|
|
102
|
-
roots: nodes.filter((node) => dependenciesByJobId[node]?.length === 0),
|
|
103
|
-
leaves: nodes.filter((node) => dependentsByJobId[node]?.length === 0),
|
|
104
|
-
issues
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
export function normalizePlanScheduleLimits(manifest, options) {
|
|
108
|
-
const maxLaneConcurrency = {};
|
|
109
|
-
for (const lane of manifest.lanes) {
|
|
110
|
-
const browserMax = lane.resourceRequirements?.browser?.maxConcurrency;
|
|
111
|
-
const value = options.maxLaneConcurrency?.[lane.id] ?? lane.maxConcurrency ?? browserMax ?? manifest.policy.defaultConcurrency;
|
|
112
|
-
maxLaneConcurrency[lane.id] = Math.max(1, Math.floor(value));
|
|
113
|
-
}
|
|
114
|
-
return {
|
|
115
|
-
...(positiveNumber(options.maxReadyJobs) ? { maxReadyJobs: Math.floor(options.maxReadyJobs) } : {}),
|
|
116
|
-
maxLaneConcurrency: { ...maxLaneConcurrency, ...(options.maxLaneConcurrency ?? {}) },
|
|
117
|
-
maxConcurrencyKeyConcurrency: { ...(options.maxConcurrencyKeyConcurrency ?? {}) },
|
|
118
|
-
maxComputeConcurrency: { ...(options.maxComputeConcurrency ?? {}) },
|
|
119
|
-
resourceQuotas: normalizeResourceQuotas(options.resourceQuotas ?? {})
|
|
120
|
-
};
|
|
121
|
-
}
|
|
122
|
-
export function validatePlanTasksForManifest(compiled, tasks, graph) {
|
|
123
|
-
const issues = [...compiled.validation.issues, ...(graph?.issues ?? [])];
|
|
124
|
-
const taskIds = new Set(tasks.map((task) => task.id));
|
|
125
|
-
for (const task of tasks) {
|
|
126
|
-
if (task.lane && !compiled.lanesById.has(task.lane))
|
|
127
|
-
addIssue(issues, 'missing-task-lane', 'error', `tasks.${task.id}.lane`, `Task lane is not declared: ${task.lane}`);
|
|
128
|
-
if (task.layer && !compiled.layersById.has(task.layer))
|
|
129
|
-
addIssue(issues, 'missing-task-layer', 'error', `tasks.${task.id}.layer`, `Task layer is not declared: ${task.layer}`);
|
|
130
|
-
if (task.compute && !compiled.computeById.has(task.compute))
|
|
131
|
-
addIssue(issues, 'missing-task-compute', 'error', `tasks.${task.id}.compute`, `Task compute is not declared: ${task.compute}`);
|
|
132
|
-
for (const dependency of task.dependsOn) {
|
|
133
|
-
if (!taskIds.has(dependency))
|
|
134
|
-
addIssue(issues, 'missing-task-dependency', 'warning', `tasks.${task.id}.dependsOn`, `Task dependency is not declared in the task set: ${dependency}`);
|
|
135
|
-
}
|
|
136
|
-
if (task.parentTaskId && !taskIds.has(task.parentTaskId))
|
|
137
|
-
addIssue(issues, 'missing-parent-task', 'warning', `tasks.${task.id}.parentTaskId`, `Task parent is not declared in the task set: ${task.parentTaskId}`);
|
|
138
|
-
}
|
|
139
|
-
return { valid: issues.every((issue) => issue.severity !== 'error'), issues };
|
|
140
|
-
}
|
|
141
|
-
export function summarizePlanJobs(jobs) {
|
|
142
|
-
return {
|
|
143
|
-
computeCount: new Set(jobs.map((job) => job.compute.id)).size,
|
|
144
|
-
layerCount: new Set(jobs.map((job) => job.layer).filter((layer) => !!layer)).size,
|
|
145
|
-
laneCount: new Set(jobs.map((job) => job.lane)).size,
|
|
146
|
-
taskCount: jobs.length,
|
|
147
|
-
jobCount: jobs.length,
|
|
148
|
-
ownershipViolationCount: jobs.reduce((total, job) => total + job.ownershipWarnings.length, 0)
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
function addIssue(issues, code, severity, path, message) {
|
|
152
|
-
issues.push({ code, severity, path, message });
|
|
153
|
-
}
|
|
154
|
-
function hasJobDependencyCycle(start, dependenciesByJobId) {
|
|
155
|
-
const visiting = new Set();
|
|
156
|
-
const visited = new Set();
|
|
157
|
-
const visit = (node) => {
|
|
158
|
-
if (visiting.has(node))
|
|
159
|
-
return true;
|
|
160
|
-
if (visited.has(node))
|
|
161
|
-
return false;
|
|
162
|
-
visiting.add(node);
|
|
163
|
-
for (const dep of dependenciesByJobId[node] ?? [])
|
|
164
|
-
if (visit(dep))
|
|
165
|
-
return true;
|
|
166
|
-
visiting.delete(node);
|
|
167
|
-
visited.add(node);
|
|
168
|
-
return false;
|
|
169
|
-
};
|
|
170
|
-
return visit(start);
|
|
171
|
-
}
|
|
172
|
-
function isPlanSwarmTask(value) {
|
|
173
|
-
return !!value && typeof value === 'object' && value.kind === 'frontier.swarm.task';
|
|
174
|
-
}
|
|
175
|
-
function mergeOwnershipRegions(laneRegions, taskRegions) {
|
|
176
|
-
const byId = new Map();
|
|
177
|
-
for (const region of laneRegions)
|
|
178
|
-
byId.set(region.id, cloneJsonValue(region));
|
|
179
|
-
for (const region of taskRegions)
|
|
180
|
-
byId.set(region.id, cloneJsonValue(region));
|
|
181
|
-
return Array.from(byId.values()).sort((left, right) => left.id.localeCompare(right.id));
|
|
182
|
-
}
|
|
183
|
-
function mergeResourceRequirements(lane, task, extraCapabilities = []) {
|
|
184
|
-
if (!lane && !task && extraCapabilities.length === 0)
|
|
185
|
-
return undefined;
|
|
186
|
-
const capabilities = uniqueStrings([...(lane?.capabilities ?? []), ...(task?.capabilities ?? []), ...extraCapabilities]);
|
|
187
|
-
const resources = { ...(lane?.resources ?? {}) };
|
|
188
|
-
for (const [key, value] of Object.entries(task?.resources ?? {}))
|
|
189
|
-
resources[key] = Math.max(resources[key] ?? 0, value);
|
|
190
|
-
const browser = task?.browser ?? lane?.browser;
|
|
191
|
-
const metadata = toJsonObject({ ...(lane?.metadata ?? {}), ...(task?.metadata ?? {}) });
|
|
192
|
-
return { capabilities, resources, ...(browser ? { browser } : {}), ...(metadata && Object.keys(metadata).length ? { metadata } : {}) };
|
|
193
|
-
}
|
|
194
|
-
function normalizeReviewPolicy(input = {}) {
|
|
195
|
-
const sampleRate = typeof input.sampleRate === 'number' && Number.isFinite(input.sampleRate) ? Math.min(1, Math.max(0, input.sampleRate)) : 0;
|
|
196
|
-
return {
|
|
197
|
-
requiredReviewers: Math.max(0, Math.floor(input.requiredReviewers ?? 0)),
|
|
198
|
-
sampleRate,
|
|
199
|
-
alwaysReview: input.alwaysReview ?? false,
|
|
200
|
-
reviewerPool: uniqueStrings(input.reviewerPool ?? []),
|
|
201
|
-
...(toJsonObject(input.metadata) ? { metadata: toJsonObject(input.metadata) } : {})
|
|
202
|
-
};
|
|
203
|
-
}
|
|
204
|
-
function normalizeResourceQuotas(input) {
|
|
205
|
-
const quotas = {};
|
|
206
|
-
for (const [resource, value] of Object.entries(input))
|
|
207
|
-
if (positiveNumber(value))
|
|
208
|
-
quotas[resource] = value;
|
|
209
|
-
return quotas;
|
|
210
|
-
}
|
|
211
|
-
function readCompute(compiled, id) {
|
|
212
|
-
return compiled.computeById.get(id) ?? compiled.computeById.get(compiled.manifest.policy.defaultCompute) ?? compiled.manifest.compute[0];
|
|
213
|
-
}
|
|
214
|
-
function resolveJobDependencies(task) {
|
|
215
|
-
return uniqueStrings([...(task.parentTaskId ? [task.parentTaskId] : []), ...task.dependsOn]);
|
|
216
|
-
}
|
|
217
|
-
function resolveLayerCompute(compiled, layerId) {
|
|
218
|
-
const layer = compiled.layersById.get(layerId);
|
|
219
|
-
if (!layer)
|
|
220
|
-
return undefined;
|
|
221
|
-
let childId = layer.id;
|
|
222
|
-
let parentId = layer.parentId;
|
|
223
|
-
while (parentId) {
|
|
224
|
-
const parent = compiled.layersById.get(parentId);
|
|
225
|
-
if (!parent)
|
|
226
|
-
break;
|
|
227
|
-
const selected = parent.childCompute[childId] ?? parent.childCompute['*'];
|
|
228
|
-
if (selected)
|
|
229
|
-
return readCompute(compiled, selected);
|
|
230
|
-
childId = parent.id;
|
|
231
|
-
parentId = parent.parentId;
|
|
232
|
-
}
|
|
233
|
-
const own = layer.compute ?? layer.defaultCompute;
|
|
234
|
-
return own ? readCompute(compiled, own) : undefined;
|
|
235
|
-
}
|
|
236
|
-
//# sourceMappingURL=plan-helpers.js.map
|