import { DropdownItem } from '@patternfly/react-core';
import { act, fireEvent, render, screen, waitFor } from '@testing-library/react';
import { ChatbotHeaderSelectorDropdown } from './ChatbotHeaderSelectorDropdown';
import '@testing-library/jest-dom';
describe('ChatbotHeaderSelectorDropdown', () => {
const dropdownItems = (
<>
Option 1
Option 2
Option 3
>
);
it('should render ChatbotHeaderSelectorDropdown', () => {
render({dropdownItems});
expect(screen.getByRole('button', { name: /Select model/i })).toBeTruthy();
});
it('should call onselect handler when a dropdown item is clicked', async () => {
const onSelect = jest.fn();
const { container } = render(
{dropdownItems}
);
act(() => {
fireEvent.click(screen.getByRole('button', { name: /Select model/i }));
});
await waitFor(() => {
expect(container.querySelector('.custom-header-selector-dropdown')).toBeTruthy();
expect(screen.getByText('Option 3'));
fireEvent.click(screen.getByText('Option 3'));
expect(onSelect).toHaveBeenCalled();
});
});
it('should handle isCompact', () => {
render(
{dropdownItems}
);
expect(screen.getByRole('button', { name: /Select model/i })).toHaveClass('pf-m-compact');
});
it('should handle toggleProps', () => {
render(
{dropdownItems}
);
expect(screen.getByRole('button', { name: /Select model/i })).toBeDisabled();
});
});