import { beforeAll, describe, expect, it, vi, afterEach } from "vitest"; import { useTerminal } from "#/hooks/use-terminal"; import { Command, useCommandStore } from "#/stores/command-store"; import { renderWithProviders } from "../../test-utils"; // Mock the WsClient context vi.mock("#/context/ws-client-provider", () => ({ useWsClient: () => ({ send: vi.fn(), status: "CONNECTED", isLoadingMessages: false, events: [], }), })); // Mock useActiveConversation vi.mock("#/hooks/query/use-active-conversation", () => ({ useActiveConversation: () => ({ data: { id: "test-conversation-id", conversation_version: "V0", }, isFetched: true, }), })); // Mock useConversationWebSocket (returns null for V0 conversations) vi.mock("#/contexts/conversation-websocket-context", () => ({ useConversationWebSocket: () => null, })); function TestTerminalComponent() { const ref = useTerminal(); return
; } describe("useTerminal", () => { // Terminal is read-only - no longer tests user input functionality const mockTerminal = vi.hoisted(() => ({ loadAddon: vi.fn(), open: vi.fn(), write: vi.fn(), writeln: vi.fn(), dispose: vi.fn(), element: document.createElement("div"), })); const mockFitAddon = vi.hoisted(() => ({ fit: vi.fn(), })); beforeAll(() => { // mock ResizeObserver - use class for Vitest 4 constructor support window.ResizeObserver = class { observe = vi.fn(); unobserve = vi.fn(); disconnect = vi.fn(); } as unknown as typeof ResizeObserver; // mock Terminal - use class for Vitest 4 constructor support vi.mock("@xterm/xterm", async (importOriginal) => ({ ...(await importOriginal