|
1 | | -// npx vitest run src/components/chat/__tests__/ChatView.spec.tsx |
| 1 | +// pnpm --filter @roo-code/vscode-webview test src/components/chat/__tests__/ChatView.spec.tsx |
2 | 2 |
|
3 | 3 | import React from "react" |
4 | 4 | import { render, waitFor, act, fireEvent } from "@/utils/test-utils" |
@@ -296,99 +296,6 @@ const renderChatView = (props: Partial<ChatViewProps> = {}) => { |
296 | 296 | describe("ChatView - Sound Playing Tests", () => { |
297 | 297 | beforeEach(() => vi.clearAllMocks()) |
298 | 298 |
|
299 | | - it("does not play sound for auto-approved browser actions", () => { |
300 | | - renderChatView() |
301 | | - |
302 | | - // First hydrate state with initial task |
303 | | - mockPostMessage({ |
304 | | - autoApprovalEnabled: true, |
305 | | - alwaysAllowBrowser: true, |
306 | | - clineMessages: [ |
307 | | - { |
308 | | - type: "say", |
309 | | - say: "task", |
310 | | - ts: Date.now() - 2000, |
311 | | - text: "Initial task", |
312 | | - }, |
313 | | - ], |
314 | | - }) |
315 | | - |
316 | | - // Clear any initial calls |
317 | | - mockPlayFunction.mockClear() |
318 | | - |
319 | | - // Add browser action that will be auto-approved |
320 | | - mockPostMessage({ |
321 | | - autoApprovalEnabled: true, |
322 | | - alwaysAllowBrowser: true, |
323 | | - clineMessages: [ |
324 | | - { |
325 | | - type: "say", |
326 | | - say: "task", |
327 | | - ts: Date.now() - 2000, |
328 | | - text: "Initial task", |
329 | | - }, |
330 | | - { |
331 | | - type: "ask", |
332 | | - ask: "browser_action_launch", |
333 | | - ts: Date.now(), |
334 | | - text: JSON.stringify({ action: "launch", url: "http://example.com" }), |
335 | | - }, |
336 | | - ], |
337 | | - }) |
338 | | - |
339 | | - // Should not play sound for auto-approved action |
340 | | - expect(mockPlayFunction).not.toHaveBeenCalled() |
341 | | - }) |
342 | | - |
343 | | - it("plays notification sound for non-auto-approved browser actions", async () => { |
344 | | - renderChatView() |
345 | | - |
346 | | - // First hydrate state with initial task |
347 | | - mockPostMessage({ |
348 | | - autoApprovalEnabled: true, |
349 | | - alwaysAllowBrowser: false, // Browser actions not auto-approved |
350 | | - soundEnabled: true, // Enable sound |
351 | | - clineMessages: [ |
352 | | - { |
353 | | - type: "say", |
354 | | - say: "task", |
355 | | - ts: Date.now() - 2000, |
356 | | - text: "Initial task", |
357 | | - }, |
358 | | - ], |
359 | | - }) |
360 | | - |
361 | | - // Clear any initial calls |
362 | | - mockPlayFunction.mockClear() |
363 | | - |
364 | | - // Add browser action that won't be auto-approved |
365 | | - mockPostMessage({ |
366 | | - autoApprovalEnabled: true, |
367 | | - alwaysAllowBrowser: false, |
368 | | - soundEnabled: true, // Enable sound |
369 | | - clineMessages: [ |
370 | | - { |
371 | | - type: "say", |
372 | | - say: "task", |
373 | | - ts: Date.now() - 2000, |
374 | | - text: "Initial task", |
375 | | - }, |
376 | | - { |
377 | | - type: "ask", |
378 | | - ask: "browser_action_launch", |
379 | | - ts: Date.now(), |
380 | | - text: JSON.stringify({ action: "launch", url: "http://example.com" }), |
381 | | - partial: false, // Ensure it's not partial |
382 | | - }, |
383 | | - ], |
384 | | - }) |
385 | | - |
386 | | - // Wait for sound to be played |
387 | | - await waitFor(() => { |
388 | | - expect(mockPlayFunction).toHaveBeenCalled() |
389 | | - }) |
390 | | - }) |
391 | | - |
392 | 299 | it("plays celebration sound for completion results", async () => { |
393 | 300 | renderChatView() |
394 | 301 |
|
|
0 commit comments