124 lines
4.8 KiB
TypeScript
124 lines
4.8 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import { buildDeepAnalysisProcessedLogDetails } from "../src/services/assistantMessageLogAssembler";
|
|
|
|
function baseInput() {
|
|
return {
|
|
sessionId: "asst-1",
|
|
messageId: "msg-1",
|
|
userMessage: "проверь 60.01",
|
|
normalizerOutput: { schema_version: "normalized_query_v2_0_2" },
|
|
executionPlan: [{ fragment_id: "F1", route: "hybrid_store_plus_live", should_execute: true }],
|
|
resolvedExecutionState: { executable: 1 },
|
|
routes: [{ fragment_id: "F1", route: "hybrid_store_plus_live" }],
|
|
retrievalCalls: [{ route: "hybrid_store_plus_live" }],
|
|
retrievalResultsRaw: [{ status: "ok" }],
|
|
retrievalResultsNormalized: [{ status: "ok" }],
|
|
requirementsExtracted: [{ requirement_id: "R1" }],
|
|
coverageReport: {
|
|
requirements_total: 1,
|
|
requirements_covered: 1,
|
|
requirements_uncovered: [],
|
|
requirements_partially_covered: [],
|
|
clarification_needed_for: [],
|
|
out_of_scope_requirements: []
|
|
},
|
|
groundingCheck: {
|
|
status: "grounded",
|
|
route_subject_match: true,
|
|
missing_requirements: [],
|
|
reasons: [],
|
|
why_included_summary: ["signal"],
|
|
selection_reason_summary: ["ranked"]
|
|
},
|
|
replyType: "factual",
|
|
droppedIntentSegments: [],
|
|
questionTypeClass: "factual_lookup",
|
|
companyAnchors: { companies: ["demo"] },
|
|
runtimeAnalysisContext: {
|
|
active: true,
|
|
as_of_date: "2020-07-31",
|
|
period_from: null,
|
|
period_to: null,
|
|
source: "eval_analysis_date",
|
|
snapshot_mode: "auto" as const
|
|
},
|
|
businessScopeResolution: {
|
|
business_scope_raw: ["company_specific_accounting"],
|
|
business_scope_resolved: ["company_specific_accounting"],
|
|
company_grounding_applied: true,
|
|
scope_resolution_reason: ["resolved"]
|
|
},
|
|
temporalGuard: {
|
|
raw_time_anchor: "2020-07",
|
|
raw_time_scope: "month",
|
|
resolved_time_anchor: "2020-07",
|
|
resolved_primary_period: { from: "2020-07-01", to: "2020-07-31", granularity: "day" },
|
|
effective_primary_period: { from: "2020-07-01", to: "2020-07-31", granularity: "day" },
|
|
temporal_guard_input: "2020-07",
|
|
temporal_alignment_status: "aligned",
|
|
temporal_resolution_source: "analysis_context",
|
|
temporal_guard_basis: "analysis_context",
|
|
temporal_guard_applied: true,
|
|
temporal_guard_outcome: "pass"
|
|
},
|
|
polarityAudit: {
|
|
raw_numeric_tokens: ["60.01"],
|
|
classified_numeric_tokens: [{ token: "60.01" }],
|
|
rejected_as_non_accounts: [],
|
|
resolved_account_anchors: ["60.01"]
|
|
},
|
|
claimAnchorAudit: {
|
|
settlement_role: "supplier",
|
|
settlement_role_resolution_reason: ["account_60_detected"],
|
|
polarity_resolution_status: "resolved"
|
|
},
|
|
targetedEvidenceAudit: { targeted_evidence_hit_rate: 1 },
|
|
evidenceAdmissibilityGateAudit: { admissible_evidence_count: 1 },
|
|
rbpLiveRouteAudit: null,
|
|
faLiveRouteAudit: null,
|
|
groundedAnswerEligibilityGuard: { eligibility_time_basis: "analysis_context", eligible: true },
|
|
followupStateUsage: null,
|
|
compositionDebug: {
|
|
problem_centric_answer_applied: true,
|
|
problem_units_used_count: 1,
|
|
problem_answer_mode: "stage3_lifecycle_aware_v1",
|
|
problem_unit_ids_used: ["pu-1"],
|
|
fallback_type: "none"
|
|
},
|
|
outcomeClassV1: "FULLY_ANSWERED",
|
|
assistantOrchestrationContractsV1: { query_frame: {}, execution_plan: {}, evidence_bundle: {}, coverage: {} },
|
|
answerStructureV11: { schema_version: "answer_structure_v1_1" },
|
|
investigationStateSnapshot: { status: "active" },
|
|
assistantReply: "ok",
|
|
traceId: "trace-1"
|
|
};
|
|
}
|
|
|
|
describe("assistant message log assembler", () => {
|
|
it("builds deep analysis log details and resolves full coverage status", () => {
|
|
const details = buildDeepAnalysisProcessedLogDetails(baseInput());
|
|
expect(details.session_id).toBe("asst-1");
|
|
expect(details.coverage_status).toBe("full");
|
|
expect(details.analysis_context).toMatchObject({
|
|
as_of_date: "2020-07-31"
|
|
});
|
|
expect(details.problem_unit_ids_used).toEqual(["pu-1"]);
|
|
expect(details.reply_type).toBe("factual");
|
|
});
|
|
|
|
it("marks partial coverage and omits optional sections when empty", () => {
|
|
const input = baseInput();
|
|
input.coverageReport.requirements_covered = 0;
|
|
input.coverageReport.requirements_uncovered = ["R1"];
|
|
input.runtimeAnalysisContext.active = false;
|
|
input.followupStateUsage = null;
|
|
input.compositionDebug.problem_unit_ids_used = [];
|
|
|
|
const details = buildDeepAnalysisProcessedLogDetails(input);
|
|
expect(details.coverage_status).toBe("partial_or_limited");
|
|
expect(details.analysis_context).toBeNull();
|
|
expect(Object.prototype.hasOwnProperty.call(details, "followup_state_usage")).toBe(false);
|
|
expect(Object.prototype.hasOwnProperty.call(details, "problem_unit_ids_used")).toBe(false);
|
|
});
|
|
});
|