Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion workers/src/orchestrate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1742,7 +1742,8 @@ async function runCatalog(
debug: {
knowledge_base_url: knowledgeBaseUrl,
baseline_url: index.baseline_url,
generated_at: index.generated_at,
generated_at: new Date().toISOString(), // response time — consistent with all other handlers
index_built_at: index.generated_at, // preserve cache-freshness diagnostic under accurate name
duration_ms: Date.now() - startMs,
},
};
Expand Down
22 changes: 22 additions & 0 deletions workers/test/canon-tool-envelope.smoke.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -603,6 +603,28 @@ async function run() {
`got: met=${prereqPass.result?.prerequisites?.required_met} total=${prereqPass.result?.prerequisites?.required_total}`,
);

// Tool: oddkit_catalog — debug.generated_at must be response time, not cached index time
console.log("\n─── Testing: oddkit_catalog ───");
const catalogResult = await callTool("oddkit", { action: "catalog", input: "recent" });
expectFullEnvelope("oddkit_catalog", catalogResult);

// debug.generated_at must be recent (under 60s) — not the cached index build time
const generatedAt = catalogResult.debug?.generated_at;
ok(`oddkit_catalog: debug.generated_at present`,
typeof generatedAt === "string" && /^\d{4}-\d{2}-\d{2}T/.test(generatedAt),
`got: ${generatedAt}`);
if (typeof generatedAt === "string") {
const ageMs = Date.now() - Date.parse(generatedAt);
ok(`oddkit_catalog: debug.generated_at is response time (age < 60s)`,
ageMs < 60_000 && ageMs >= 0,
`ageMs=${ageMs}`);
}

// index_built_at is the separate, accurately-named cache-freshness diagnostic
ok(`oddkit_catalog: debug.index_built_at present`,
typeof catalogResult.debug?.index_built_at === "string",
`got: ${catalogResult.debug?.index_built_at}`);

console.log(`\n${passed} passed, ${failed} failed`);
process.exit(failed === 0 ? 0 : 1);
}
Expand Down
Loading