2025-09-18 11:54:09 -07:00
|
|
|
/**
|
|
|
|
|
* @license
|
|
|
|
|
* Copyright 2025 Google LLC
|
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
import { describe, it, expect } from 'vitest';
|
2025-10-30 11:50:26 -07:00
|
|
|
import { render } from '../../test-utils/render.js';
|
2025-09-18 11:54:09 -07:00
|
|
|
import { QueuedMessageDisplay } from './QueuedMessageDisplay.js';
|
|
|
|
|
|
|
|
|
|
describe('QueuedMessageDisplay', () => {
|
|
|
|
|
it('renders nothing when message queue is empty', () => {
|
2025-10-30 11:50:26 -07:00
|
|
|
const { lastFrame, unmount } = render(
|
|
|
|
|
<QueuedMessageDisplay messageQueue={[]} />,
|
|
|
|
|
);
|
2025-09-18 11:54:09 -07:00
|
|
|
|
|
|
|
|
expect(lastFrame()).toBe('');
|
2025-10-30 11:50:26 -07:00
|
|
|
unmount();
|
2025-09-18 11:54:09 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('displays single queued message', () => {
|
2025-10-30 11:50:26 -07:00
|
|
|
const { lastFrame, unmount } = render(
|
2025-09-18 11:54:09 -07:00
|
|
|
<QueuedMessageDisplay messageQueue={['First message']} />,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const output = lastFrame();
|
2025-10-16 17:04:13 -07:00
|
|
|
expect(output).toContain('Queued (press ↑ to edit):');
|
2025-09-18 11:54:09 -07:00
|
|
|
expect(output).toContain('First message');
|
2025-10-30 11:50:26 -07:00
|
|
|
unmount();
|
2025-09-18 11:54:09 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('displays multiple queued messages', () => {
|
|
|
|
|
const messageQueue = [
|
|
|
|
|
'First queued message',
|
|
|
|
|
'Second queued message',
|
|
|
|
|
'Third queued message',
|
|
|
|
|
];
|
|
|
|
|
|
2025-10-30 11:50:26 -07:00
|
|
|
const { lastFrame, unmount } = render(
|
2025-09-18 11:54:09 -07:00
|
|
|
<QueuedMessageDisplay messageQueue={messageQueue} />,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const output = lastFrame();
|
2025-10-16 17:04:13 -07:00
|
|
|
expect(output).toContain('Queued (press ↑ to edit):');
|
2025-09-18 11:54:09 -07:00
|
|
|
expect(output).toContain('First queued message');
|
|
|
|
|
expect(output).toContain('Second queued message');
|
|
|
|
|
expect(output).toContain('Third queued message');
|
2025-10-30 11:50:26 -07:00
|
|
|
unmount();
|
2025-09-18 11:54:09 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('shows overflow indicator when more than 3 messages are queued', () => {
|
|
|
|
|
const messageQueue = [
|
|
|
|
|
'Message 1',
|
|
|
|
|
'Message 2',
|
|
|
|
|
'Message 3',
|
|
|
|
|
'Message 4',
|
|
|
|
|
'Message 5',
|
|
|
|
|
];
|
|
|
|
|
|
2025-10-30 11:50:26 -07:00
|
|
|
const { lastFrame, unmount } = render(
|
2025-09-18 11:54:09 -07:00
|
|
|
<QueuedMessageDisplay messageQueue={messageQueue} />,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const output = lastFrame();
|
2025-10-16 17:04:13 -07:00
|
|
|
expect(output).toContain('Queued (press ↑ to edit):');
|
2025-09-18 11:54:09 -07:00
|
|
|
expect(output).toContain('Message 1');
|
|
|
|
|
expect(output).toContain('Message 2');
|
|
|
|
|
expect(output).toContain('Message 3');
|
|
|
|
|
expect(output).toContain('... (+2 more)');
|
|
|
|
|
expect(output).not.toContain('Message 4');
|
|
|
|
|
expect(output).not.toContain('Message 5');
|
2025-10-30 11:50:26 -07:00
|
|
|
unmount();
|
2025-09-18 11:54:09 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('normalizes whitespace in messages', () => {
|
|
|
|
|
const messageQueue = ['Message with\tmultiple\n whitespace'];
|
|
|
|
|
|
2025-10-30 11:50:26 -07:00
|
|
|
const { lastFrame, unmount } = render(
|
2025-09-18 11:54:09 -07:00
|
|
|
<QueuedMessageDisplay messageQueue={messageQueue} />,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const output = lastFrame();
|
2025-10-16 17:04:13 -07:00
|
|
|
expect(output).toContain('Queued (press ↑ to edit):');
|
2025-09-18 11:54:09 -07:00
|
|
|
expect(output).toContain('Message with multiple whitespace');
|
2025-10-30 11:50:26 -07:00
|
|
|
unmount();
|
2025-09-18 11:54:09 -07:00
|
|
|
});
|
|
|
|
|
});
|