Accept Scattermind roadmap proof labels
This commit is contained in:
@@ -2036,6 +2036,59 @@ try {
|
||||
assert.equal(buildOrderPreview.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(buildOrderPreview.handoff.warnings, []);
|
||||
|
||||
const scattermindRoadmapLanguageResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
sourceName: 'Scattermind',
|
||||
referenceCode: 'SM-ROADMAP-LANGUAGE-1',
|
||||
working_name: 'Snapshot roadmap preview language',
|
||||
ideaText: 'Scattermind free Snapshot language says Build first / Validate manually / Defer / Probably noise.',
|
||||
context: 'Solo builder. Manual proof first. Avoid saved workspaces and account dashboards before evidence.',
|
||||
mode: 'mvp',
|
||||
lenses: {
|
||||
channel: 'Build first: Smallest useful offer page - one tiny before/after moment for the core user. Validate manually: Proof of core user pull - ask three real users what they would do next. Defer: Anything that does not prove the core loop. Probably noise: Big-version feature creep with accounts, dashboards, billing, and saved workspaces.',
|
||||
risk: 'Avoid saved workspaces and account dashboards before the first manual proof lands.',
|
||||
},
|
||||
buildOrderPreview: {
|
||||
buildNow: [{ id: 'roadmap-copy-strip', action: 'Roadmap copy strip', evidence_needed: 'Can a tired user read the strip and name the first move?', source_item_id: 'roadmap-strip-1', source_title: 'Snapshot roadmap preview', ranker_hints: { value: 9, effort: 2, confidence: 8, urgency: 8, risk: 2 } }],
|
||||
validateManually: [{ id: 'roadmap-manual-proof', action: 'Roadmap manual proof', evidence_needed: 'Can three real users explain the next move without a dashboard?', source_item_id: 'roadmap-strip-2', source_title: 'Snapshot roadmap preview' }],
|
||||
probablyNoise: [{ id: 'roadmap-account-dashboard', action: 'Roadmap account dashboard', evidence_needed: 'Not before proof.', source_item_id: 'roadmap-strip-3', source_title: 'Snapshot roadmap preview' }],
|
||||
},
|
||||
}),
|
||||
});
|
||||
assert.equal(scattermindRoadmapLanguageResponse.status, 200);
|
||||
const scattermindRoadmapLanguage = await scattermindRoadmapLanguageResponse.json();
|
||||
assert.equal(scattermindRoadmapLanguage.input.optionCount, 3, 'Build Order Preview object should accept validateManually / probablyNoise keys without falling back to lens text');
|
||||
assert.equal(scattermindRoadmapLanguage.ranked[0].id, 'roadmap-copy-strip');
|
||||
assert.equal(scattermindRoadmapLanguage.ranked.find(item => item.id === 'roadmap-manual-proof').lane.id, 'test');
|
||||
assert.equal(scattermindRoadmapLanguage.ranked.find(item => item.id === 'roadmap-manual-proof').provenance.sourceSection, 'buildOrderPreview.validateNext');
|
||||
assert.equal(scattermindRoadmapLanguage.ranked.find(item => item.id === 'roadmap-account-dashboard').lane.id, 'park');
|
||||
assert.equal(scattermindRoadmapLanguage.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(scattermindRoadmapLanguage.handoff.warnings, []);
|
||||
|
||||
const scattermindRoadmapLensOnlyResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
sourceName: 'Scattermind',
|
||||
referenceCode: 'SM-ROADMAP-LENS-ONLY-1',
|
||||
working_name: 'Roadmap preview lens-only language',
|
||||
ideaText: 'The user pasted only the visible Scattermind roadmap preview copy.',
|
||||
context: 'Solo builder. Manual proof first. Avoid account dashboards.',
|
||||
mode: 'mvp',
|
||||
lenses: {
|
||||
channel: 'Build first: Smallest useful Snapshot-to-Ranker handoff. Validate manually: Proof of tired-user comprehension. Defer: Anything that does not prove the core loop. Probably noise: Big-version feature creep with account dashboards.',
|
||||
},
|
||||
}),
|
||||
});
|
||||
assert.equal(scattermindRoadmapLensOnlyResponse.status, 200);
|
||||
const scattermindRoadmapLensOnly = await scattermindRoadmapLensOnlyResponse.json();
|
||||
assert.equal(scattermindRoadmapLensOnly.input.optionCount, 4);
|
||||
assert.equal(scattermindRoadmapLensOnly.ranked.find(item => item.id === 'build-order-2').lane.id, 'test', 'Validate manually label should parse into Validate next instead of being dropped');
|
||||
assert.match(scattermindRoadmapLensOnly.ranked.find(item => item.id === 'build-order-2').provenance.sourceQuote, /Validate manually:/);
|
||||
assert.equal(scattermindRoadmapLensOnly.ranked.find(item => item.id === 'build-order-4').lane.id, 'park');
|
||||
|
||||
const stringifiedRankerInputResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
@@ -2108,7 +2161,7 @@ try {
|
||||
assert.equal(gameRouteGuardrail.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(gameRouteGuardrail.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, stringifiedRankerInputTop: stringifiedRankerInput.ranked[0].id, gameRouteGuardrailTop: gameRouteGuardrail.ranked[0].id, duplicateIds: duplicateIds.ranked.map(item => item.id), readiness: data.handoff.readiness.status, provenance: data.input.provenance, buildOrder: data.buildOrder }, null, 2));
|
||||
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, gameRouteGuardrailTop: gameRouteGuardrail.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