Fix tests to wrap all calls changing the UI with act. (#12268)

This commit is contained in:
Jacob Richman
2025-10-30 11:50:26 -07:00
committed by GitHub
parent cc081337b7
commit 54fa26ef0e
69 changed files with 2002 additions and 1291 deletions

View File

@@ -5,24 +5,28 @@
*/
import { describe, it, expect } from 'vitest';
import { render } from 'ink-testing-library';
import { render } from '../../test-utils/render.js';
import { QueuedMessageDisplay } from './QueuedMessageDisplay.js';
describe('QueuedMessageDisplay', () => {
it('renders nothing when message queue is empty', () => {
const { lastFrame } = render(<QueuedMessageDisplay messageQueue={[]} />);
const { lastFrame, unmount } = render(
<QueuedMessageDisplay messageQueue={[]} />,
);
expect(lastFrame()).toBe('');
unmount();
});
it('displays single queued message', () => {
const { lastFrame } = render(
const { lastFrame, unmount } = render(
<QueuedMessageDisplay messageQueue={['First message']} />,
);
const output = lastFrame();
expect(output).toContain('Queued (press ↑ to edit):');
expect(output).toContain('First message');
unmount();
});
it('displays multiple queued messages', () => {
@@ -32,7 +36,7 @@ describe('QueuedMessageDisplay', () => {
'Third queued message',
];
const { lastFrame } = render(
const { lastFrame, unmount } = render(
<QueuedMessageDisplay messageQueue={messageQueue} />,
);
@@ -41,6 +45,7 @@ describe('QueuedMessageDisplay', () => {
expect(output).toContain('First queued message');
expect(output).toContain('Second queued message');
expect(output).toContain('Third queued message');
unmount();
});
it('shows overflow indicator when more than 3 messages are queued', () => {
@@ -52,7 +57,7 @@ describe('QueuedMessageDisplay', () => {
'Message 5',
];
const { lastFrame } = render(
const { lastFrame, unmount } = render(
<QueuedMessageDisplay messageQueue={messageQueue} />,
);
@@ -64,17 +69,19 @@ describe('QueuedMessageDisplay', () => {
expect(output).toContain('... (+2 more)');
expect(output).not.toContain('Message 4');
expect(output).not.toContain('Message 5');
unmount();
});
it('normalizes whitespace in messages', () => {
const messageQueue = ['Message with\tmultiple\n whitespace'];
const { lastFrame } = render(
const { lastFrame, unmount } = render(
<QueuedMessageDisplay messageQueue={messageQueue} />,
);
const output = lastFrame();
expect(output).toContain('Queued (press ↑ to edit):');
expect(output).toContain('Message with multiple whitespace');
unmount();
});
});