/** * @license * Copyright 2025 Google LLC * SPDX-License-Identifier: Apache-2.0 */ import { renderWithProviders } from '../../test-utils/render.js'; import { DetailedMessagesDisplay } from './DetailedMessagesDisplay.js'; import { describe, it, expect, vi } from 'vitest'; import type { ConsoleMessageItem } from '../types.js'; import { Box } from 'ink'; import type React from 'react'; import { createMockSettings } from '../../test-utils/settings.js'; vi.mock('./shared/ScrollableList.js', () => ({ ScrollableList: ({ data, renderItem, }: { data: unknown[]; renderItem: (props: { item: unknown }) => React.ReactNode; }) => ( {data.map((item: unknown, index: number) => ( {renderItem({ item })} ))} ), })); describe('DetailedMessagesDisplay', () => { it('renders nothing when messages are empty', async () => { const { lastFrame, waitUntilReady, unmount } = renderWithProviders( , { settings: createMockSettings({ merged: { ui: { errorVerbosity: 'full' } }, }), }, ); await waitUntilReady(); expect(lastFrame({ allowEmpty: true })).toBe(''); unmount(); }); it('renders messages correctly', async () => { const messages: ConsoleMessageItem[] = [ { type: 'log', content: 'Log message', count: 1 }, { type: 'warn', content: 'Warning message', count: 1 }, { type: 'error', content: 'Error message', count: 1 }, { type: 'debug', content: 'Debug message', count: 1 }, ]; const { lastFrame, waitUntilReady, unmount } = renderWithProviders( , { settings: createMockSettings({ merged: { ui: { errorVerbosity: 'full' } }, }), }, ); await waitUntilReady(); const output = lastFrame(); expect(output).toMatchSnapshot(); unmount(); }); it('shows the F12 hint even in low error verbosity mode', async () => { const messages: ConsoleMessageItem[] = [ { type: 'error', content: 'Error message', count: 1 }, ]; const { lastFrame, waitUntilReady, unmount } = renderWithProviders( , { settings: createMockSettings({ merged: { ui: { errorVerbosity: 'low' } }, }), }, ); await waitUntilReady(); expect(lastFrame()).toContain('(F12 to close)'); unmount(); }); it('shows the F12 hint in full error verbosity mode', async () => { const messages: ConsoleMessageItem[] = [ { type: 'error', content: 'Error message', count: 1 }, ]; const { lastFrame, waitUntilReady, unmount } = renderWithProviders( , { settings: createMockSettings({ merged: { ui: { errorVerbosity: 'full' } }, }), }, ); await waitUntilReady(); expect(lastFrame()).toContain('(F12 to close)'); unmount(); }); it('renders message counts', async () => { const messages: ConsoleMessageItem[] = [ { type: 'log', content: 'Repeated message', count: 5 }, ]; const { lastFrame, waitUntilReady, unmount } = renderWithProviders( , { settings: createMockSettings({ merged: { ui: { errorVerbosity: 'full' } }, }), }, ); await waitUntilReady(); const output = lastFrame(); expect(output).toMatchSnapshot(); unmount(); }); });