Accept proof plan bridge aliases
This commit is contained in:
@@ -2520,7 +2520,37 @@ try {
|
||||
assert.equal(rankedBuildOrderAlias.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(rankedBuildOrderAlias.handoff.warnings, []);
|
||||
|
||||
console.log(JSON.stringify({ ok: true, top: data.ranked[0].id, hintedTop: hinted.ranked[0].id, actionTop: actions.ranked[0].id, nestedConceptTop: nestedConcept.ranked[0].id, nonGoalTop: nonGoal.ranked[0].id, structuredContextTop: structuredContext.ranked[0].id, lensOnlyTop: lensOnly.ranked[0].id, scattermindPaidShapeTop: scattermindPaidShape.ranked[0].id, mergedContextTop: mergedContext.ranked[0].id, embeddedJsonTop: embeddedJson.ranked[0].id, fencedJsonTop: fencedJson.ranked[0].id, embeddedSnapshotTop: embeddedSnapshot.ranked[0].id, sourceExcerptTop: sourceExcerpt.ranked[0].id, snakeCaseBridgeTop: snakeCaseBridge.ranked[0].id, nextStepsAliasTop: nextStepsAlias.ranked[0].id, summaryGuardrailTop: summaryGuardrail.ranked[0].id, bridgeEnvelopeTop: bridgeEnvelope.ranked[0].id, directEnvelopeSectionsTop: directEnvelopeSections.ranked[0].id, softDirectLaneAliasesTop: softDirectLaneAliases.ranked[0].id, threadsFallbackTop: threadsFallback.ranked[0].id, questionsFallbackTop: questionsFallback.ranked[0].id, freeSnapshotTop: freeSnapshot.ranked[0].id, storedScattermindRowTop: storedScattermindRow.ranked[0].id, candidateActionsAliasTop: candidateActionsAlias.ranked[0].id, rankReadyActionsEnvelopeTop: rankReadyActionsEnvelope.ranked[0].id, continuationEnvelopeTop: continuationEnvelope.ranked[0].id, buildOrderPreviewTop: buildOrderPreview.ranked[0].id, scattermindRoadmapLanguageTop: scattermindRoadmapLanguage.ranked[0].id, scattermindRoadmapLensOnlyTop: scattermindRoadmapLensOnly.ranked[0].id, stringifiedRankerInputTop: stringifiedRankerInput.ranked[0].id, scalarBuildOrderSectionsTop: scalarBuildOrderSections.ranked[0].id, snakeReaderFriendlyBuildOrderTop: snakeReaderFriendlyBuildOrder.ranked[0].id, readerFriendlyLensLabelTop: readerFriendlyLensLabel.ranked[0].id, gameRouteGuardrailTop: gameRouteGuardrail.ranked[0].id, rankedBuildOrderAliasTop: rankedBuildOrderAlias.ranked[0].id, duplicateIds: duplicateIds.ranked.map(item => item.id), readiness: data.handoff.readiness.status, provenance: data.input.provenance, buildOrder: data.buildOrder }, null, 2));
|
||||
|
||||
const proofPlanAliasResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
sourceName: 'Scattermind',
|
||||
referenceCode: 'SM-PROOF-PLAN-ALIAS-1',
|
||||
working_name: 'Proof Plan alias export',
|
||||
ideaText: 'Scattermind exported a reader-facing proof plan and validation plan instead of software feature names.',
|
||||
context: 'Solo builder. Manual proof first. Avoid account dashboards and saved workspaces until proof.',
|
||||
mode: 'validation',
|
||||
conceptMap: {
|
||||
doFirst: [{ id: 'proof-plan-active', action: 'One-call source-traced proof offer', evidence_needed: 'Can one target user explain the first move after reading the receipt?', source_item_id: 'proof-plan-active-1', source_title: 'Build Order', ranker_hints: { value: 8, effort: 2, confidence: 7, urgency: 8, risk: 2 } }],
|
||||
proof_plan: [{ id: 'proof-plan-call', action: 'Run the first proof call', evidence_needed: 'Does a tired user understand the active slice without a dashboard?', source_item_id: 'proof-plan-1', source_title: 'Proof Plan' }],
|
||||
validation_plan: [{ id: 'validation-plan-recheck', action: 'Re-rank after the proof call', evidence_needed: 'Did the first proof change the defended build order?', source_item_id: 'validation-plan-1', source_title: 'Validation Plan' }],
|
||||
parkingLot: [{ id: 'proof-plan-dashboard', action: 'Saved proof dashboard with accounts and billing', evidence_needed: 'Not before proof.', source_item_id: 'parking-1', source_title: 'Parking Lot' }],
|
||||
},
|
||||
}),
|
||||
});
|
||||
assert.equal(proofPlanAliasResponse.status, 200);
|
||||
const proofPlanAlias = await proofPlanAliasResponse.json();
|
||||
assert.equal(proofPlanAlias.input.optionCount, 4, 'proof_plan / validation_plan should become validate-next candidates without renaming them to features');
|
||||
assert.equal(proofPlanAlias.ranked[0].id, 'proof-plan-active');
|
||||
assert.equal(proofPlanAlias.ranked.find(item => item.id === 'proof-plan-call').lane.id, 'test');
|
||||
assert.equal(proofPlanAlias.ranked.find(item => item.id === 'validation-plan-recheck').lane.id, 'test');
|
||||
assert.equal(proofPlanAlias.ranked.find(item => item.id === 'proof-plan-dashboard').lane.id, 'park');
|
||||
assert.equal(proofPlanAlias.ranked.find(item => item.id === 'proof-plan-call').provenance.sourceSection, 'concept-map.experiments');
|
||||
assert.equal(proofPlanAlias.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(proofPlanAlias.handoff.warnings, []);
|
||||
|
||||
console.log(JSON.stringify({ ok: true, top: data.ranked[0].id, hintedTop: hinted.ranked[0].id, actionTop: actions.ranked[0].id, nestedConceptTop: nestedConcept.ranked[0].id, nonGoalTop: nonGoal.ranked[0].id, structuredContextTop: structuredContext.ranked[0].id, lensOnlyTop: lensOnly.ranked[0].id, scattermindPaidShapeTop: scattermindPaidShape.ranked[0].id, mergedContextTop: mergedContext.ranked[0].id, embeddedJsonTop: embeddedJson.ranked[0].id, fencedJsonTop: fencedJson.ranked[0].id, embeddedSnapshotTop: embeddedSnapshot.ranked[0].id, sourceExcerptTop: sourceExcerpt.ranked[0].id, snakeCaseBridgeTop: snakeCaseBridge.ranked[0].id, nextStepsAliasTop: nextStepsAlias.ranked[0].id, summaryGuardrailTop: summaryGuardrail.ranked[0].id, bridgeEnvelopeTop: bridgeEnvelope.ranked[0].id, directEnvelopeSectionsTop: directEnvelopeSections.ranked[0].id, softDirectLaneAliasesTop: softDirectLaneAliases.ranked[0].id, threadsFallbackTop: threadsFallback.ranked[0].id, questionsFallbackTop: questionsFallback.ranked[0].id, freeSnapshotTop: freeSnapshot.ranked[0].id, storedScattermindRowTop: storedScattermindRow.ranked[0].id, candidateActionsAliasTop: candidateActionsAlias.ranked[0].id, rankReadyActionsEnvelopeTop: rankReadyActionsEnvelope.ranked[0].id, continuationEnvelopeTop: continuationEnvelope.ranked[0].id, buildOrderPreviewTop: buildOrderPreview.ranked[0].id, scattermindRoadmapLanguageTop: scattermindRoadmapLanguage.ranked[0].id, scattermindRoadmapLensOnlyTop: scattermindRoadmapLensOnly.ranked[0].id, stringifiedRankerInputTop: stringifiedRankerInput.ranked[0].id, scalarBuildOrderSectionsTop: scalarBuildOrderSections.ranked[0].id, snakeReaderFriendlyBuildOrderTop: snakeReaderFriendlyBuildOrder.ranked[0].id, readerFriendlyLensLabelTop: readerFriendlyLensLabel.ranked[0].id, gameRouteGuardrailTop: gameRouteGuardrail.ranked[0].id, rankedBuildOrderAliasTop: rankedBuildOrderAlias.ranked[0].id, proofPlanAliasTop: proofPlanAlias.ranked[0].id, duplicateIds: duplicateIds.ranked.map(item => item.id), readiness: data.handoff.readiness.status, provenance: data.input.provenance, buildOrder: data.buildOrder }, null, 2));
|
||||
} finally {
|
||||
server.kill('SIGTERM');
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user