|
| 1 | +import { render, screen, userEvent } from '@/test-utils/rtl'; |
| 2 | + |
| 3 | +import { mockDomainPageHelpMenuConfig } from '../../__fixtures__/domain-page-help-menu-config'; |
| 4 | +import DomainPageHelpItemButton from '../domain-page-help-item-button'; |
| 5 | + |
| 6 | +const linkItem = mockDomainPageHelpMenuConfig[0].items[0]; |
| 7 | +const modalItem = mockDomainPageHelpMenuConfig[1].items[0]; |
| 8 | +const otherItem = mockDomainPageHelpMenuConfig[2].items[0]; |
| 9 | + |
| 10 | +describe(DomainPageHelpItemButton.name, () => { |
| 11 | + beforeEach(() => { |
| 12 | + jest.clearAllMocks(); |
| 13 | + }); |
| 14 | + |
| 15 | + it('renders a link button correctly', () => { |
| 16 | + render(<DomainPageHelpItemButton {...linkItem} />); |
| 17 | + |
| 18 | + const linkItemButton = screen.getByRole('link'); |
| 19 | + expect(linkItemButton).toBeInTheDocument(); |
| 20 | + |
| 21 | + expect(linkItemButton).toHaveTextContent('Get started (docs)'); |
| 22 | + expect(linkItemButton).toHaveAttribute('target', '_blank'); |
| 23 | + expect(linkItemButton).toHaveAttribute('rel', 'noreferrer'); |
| 24 | + expect(linkItemButton).toHaveAttribute('href', 'https://mock.docs.link'); |
| 25 | + |
| 26 | + expect(screen.getByText('Docs Icon')).toBeInTheDocument(); |
| 27 | + }); |
| 28 | + |
| 29 | + it('renders a modal button correctly and opens the modal on click', async () => { |
| 30 | + const user = userEvent.setup(); |
| 31 | + render(<DomainPageHelpItemButton {...modalItem} />); |
| 32 | + |
| 33 | + const buttonElement = screen.getByText('Domain commands'); |
| 34 | + expect(buttonElement).toBeInTheDocument(); |
| 35 | + |
| 36 | + expect(screen.getByText('Cmds Icon')).toBeInTheDocument(); |
| 37 | + |
| 38 | + expect(screen.getByText('Closed modal')).toBeInTheDocument(); |
| 39 | + |
| 40 | + await user.click(buttonElement); |
| 41 | + |
| 42 | + expect(await screen.findByText('Open modal')).toBeInTheDocument(); |
| 43 | + }); |
| 44 | + |
| 45 | + it('renders an action button correctly and calls onClick handler', async () => { |
| 46 | + const user = userEvent.setup(); |
| 47 | + render(<DomainPageHelpItemButton {...otherItem} />); |
| 48 | + |
| 49 | + const button = screen.getByText('Custom action'); |
| 50 | + expect(button).toBeInTheDocument(); |
| 51 | + |
| 52 | + expect(screen.getByText('Other Icon')).toBeInTheDocument(); |
| 53 | + |
| 54 | + await user.click(button); |
| 55 | + |
| 56 | + expect(otherItem.onClick).toHaveBeenCalledTimes(1); |
| 57 | + }); |
| 58 | +}); |
0 commit comments