Accept free Scattermind snapshot handoffs
This commit is contained in:
@@ -1285,6 +1285,37 @@ try {
|
||||
assert.equal(questionsFallback.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(questionsFallback.handoff.warnings, []);
|
||||
|
||||
const freeSnapshotResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
body: JSON.stringify({
|
||||
working_name: 'Free Snapshot Bridge',
|
||||
restated_idea: 'A free Scattermind Snapshot clarified a rough service idea, but it has not produced a paid Build Order yet.',
|
||||
lenses: {
|
||||
shape: {
|
||||
title: 'Product Shape',
|
||||
content: 'Start with a manual promise test for one service buyer. Do not build accounts, saved workspaces, or a dashboard before someone reacts to the offer.',
|
||||
},
|
||||
},
|
||||
questions_to_sit_with: ['Will one target buyer ask for the manual promise after seeing the short explanation?'],
|
||||
reference_code: 'SM-FREE-SNAPSHOT-1',
|
||||
tags: ['manual proof', 'buyer signal'],
|
||||
mode: 'mvp',
|
||||
}),
|
||||
});
|
||||
assert.equal(freeSnapshotResponse.status, 200);
|
||||
const freeSnapshot = await freeSnapshotResponse.json();
|
||||
assert.equal(freeSnapshot.input.provenance.artifactId, 'SM-FREE-SNAPSHOT-1');
|
||||
assert.equal(freeSnapshot.input.provenance.snapshotTitle, 'Free Snapshot Bridge');
|
||||
assert.match(freeSnapshot.input.provenance.sourceSummary, /rough service idea/);
|
||||
assert.equal(freeSnapshot.input.optionCount, 2);
|
||||
assert.equal(freeSnapshot.ranked[0].id, 'snapshot-manual-proof');
|
||||
assert.equal(freeSnapshot.ranked[0].provenance.sourceSection, 'snapshot.lenses.shape');
|
||||
assert.match(freeSnapshot.ranked[0].factors.evidenceNeeded, /target buyer/);
|
||||
assert.equal(freeSnapshot.ranked.find(item => item.id === 'question-1').lane.id, 'test');
|
||||
assert.equal(freeSnapshot.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(freeSnapshot.handoff.warnings, []);
|
||||
|
||||
const storedScattermindRowResponse = await fetch(`${base}/api/rank-feedback`, {
|
||||
method: 'POST',
|
||||
headers: { 'Content-Type': 'application/json' },
|
||||
@@ -1321,7 +1352,7 @@ try {
|
||||
assert.equal(storedScattermindRow.handoff.readiness.status, 'ready');
|
||||
assert.deepEqual(storedScattermindRow.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, storedScattermindRowTop: storedScattermindRow.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, 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