Accept reader-friendly Scattermind build order aliases
This commit is contained in:
@@ -2313,6 +2313,61 @@ try {
|
||||
assert.equal(scalarBuildOrderSections.handoff.readiness.status, 'needs-source-context');
|
||||
assert.ok(scalarBuildOrderSections.handoff.warnings.includes('missing evidence needed for active item feature-1'));
|
||||
|
||||
const snakeReaderFriendlyBuildOrderResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
sourceName: 'Scattermind',
|
||||
referenceCode: 'SM-SNAKE-READER-BUILD-ORDER-1',
|
||||
working_name: 'Reader-friendly snake Build Order',
|
||||
ideaText: 'Scattermind exported snake_case Build Order keys and visible labels like Test this manually / Do not build this yet.',
|
||||
context: 'Solo builder. Manual proof first. Avoid account dashboards and saved workspaces until one user acts.',
|
||||
mode: 'mvp',
|
||||
conceptMap: {
|
||||
build_order_preview: {
|
||||
build_first: [{ id: 'snake-source-preview', action: 'Snake-case source preview', evidence_needed: 'Can the snake_case build order still name one active source-traced move?', source_item_id: 'snake-build-1', source_title: 'Reader-friendly Build Order', ranker_hints: { value: 9, effort: 2, confidence: 8, urgency: 8, risk: 2 } }],
|
||||
test_next: [{ id: 'snake-manual-test', action: 'Snake-case manual test', evidence_needed: 'Does the user know what signal to collect?', source_item_id: 'snake-test-1', source_title: 'Reader-friendly Build Order' }],
|
||||
do_not_build_yet: [{ id: 'snake-saved-workspace', action: 'Snake-case saved workspace dashboard', evidence_needed: 'Not before proof.', source_item_id: 'snake-defer-1', source_title: 'Reader-friendly Build Order' }],
|
||||
probably_noise: [{ id: 'snake-billing-admin', action: 'Snake-case billing and admin layer', evidence_needed: 'Not part of the bridge proof.', source_item_id: 'snake-park-1', source_title: 'Reader-friendly Build Order' }],
|
||||
},
|
||||
lenses: {
|
||||
channel: { title: 'Build Order', content: 'Build first: Source preview from Concept Map. Test this manually: Ask one tired user to explain the first move. Do not build this yet: saved workspace dashboard. Probably noise: billing admin before proof.' },
|
||||
},
|
||||
},
|
||||
}),
|
||||
});
|
||||
assert.equal(snakeReaderFriendlyBuildOrderResponse.status, 200);
|
||||
const snakeReaderFriendlyBuildOrder = await snakeReaderFriendlyBuildOrderResponse.json();
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.input.optionCount, 4, 'snake_case Build Order keys should beat falling back to reader-facing lens text');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.ranked[0].id, 'snake-source-preview');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.ranked[0].provenance.sourceSection, 'concept-map.buildOrderPreview.doFirst');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.ranked.find(item => item.id === 'snake-manual-test').lane.id, 'test');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.ranked.find(item => item.id === 'snake-saved-workspace').lane.id, 'defer');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.ranked.find(item => item.id === 'snake-billing-admin').lane.id, 'park');
|
||||
assert.equal(snakeReaderFriendlyBuildOrder.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(snakeReaderFriendlyBuildOrder.handoff.warnings, []);
|
||||
|
||||
const readerFriendlyLensLabelResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
sourceName: 'Scattermind',
|
||||
referenceCode: 'SM-THIS-LABELS-1',
|
||||
working_name: 'This-label Build Order',
|
||||
ideaText: 'A paid Concept Map was copied as visible Build Order prose only.',
|
||||
mode: 'mvp',
|
||||
lenses: {
|
||||
channel: 'Build first: One-page source receipt. Test this manually: Ask one tired user what to do next. Do not build this yet: saved account workspace. Probably noise: subscription dashboard before proof.',
|
||||
},
|
||||
}),
|
||||
});
|
||||
assert.equal(readerFriendlyLensLabelResponse.status, 200);
|
||||
const readerFriendlyLensLabel = await readerFriendlyLensLabelResponse.json();
|
||||
assert.equal(readerFriendlyLensLabel.input.optionCount, 4);
|
||||
assert.equal(readerFriendlyLensLabel.ranked.find(item => item.id === 'build-order-2').lane.id, 'test');
|
||||
assert.equal(readerFriendlyLensLabel.ranked.find(item => item.id === 'build-order-3').lane.id, 'defer');
|
||||
assert.equal(readerFriendlyLensLabel.ranked.find(item => item.id === 'build-order-4').lane.id, 'park');
|
||||
|
||||
const gameRouteGuardrailResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
@@ -2350,7 +2405,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, scattermindRoadmapLanguageTop: scattermindRoadmapLanguage.ranked[0].id, scattermindRoadmapLensOnlyTop: scattermindRoadmapLensOnly.ranked[0].id, stringifiedRankerInputTop: stringifiedRankerInput.ranked[0].id, scalarBuildOrderSectionsTop: scalarBuildOrderSections.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, scalarBuildOrderSectionsTop: scalarBuildOrderSections.ranked[0].id, snakeReaderFriendlyBuildOrderTop: snakeReaderFriendlyBuildOrder.ranked[0].id, readerFriendlyLensLabelTop: readerFriendlyLensLabel.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