mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-10 02:07:26 +03:00
29 lines
1,008 B
TypeScript
29 lines
1,008 B
TypeScript
|
import { screen } from '@testing-library/react';
|
||
|
import { fromPartial } from '@total-typescript/shoehorn';
|
||
|
import type { DropdownBtnMenuProps } from '../../src/utils/RowDropdownBtn';
|
||
|
import { RowDropdownBtn } from '../../src/utils/RowDropdownBtn';
|
||
|
import { renderWithEvents } from '../__helpers__/setUpTest';
|
||
|
|
||
|
describe('<RowDropdownBtn />', () => {
|
||
|
const setUp = (props: Partial<DropdownBtnMenuProps> = {}) => renderWithEvents(
|
||
|
<RowDropdownBtn {...fromPartial<DropdownBtnMenuProps>({ ...props })}>
|
||
|
the children
|
||
|
</RowDropdownBtn>,
|
||
|
);
|
||
|
|
||
|
it('renders expected components', () => {
|
||
|
setUp();
|
||
|
const toggle = screen.getByRole('button');
|
||
|
|
||
|
expect(toggle).toBeInTheDocument();
|
||
|
expect(toggle).toHaveClass('btn-sm');
|
||
|
expect(toggle).toHaveClass('dropdown-btn__toggle');
|
||
|
expect(screen.getByRole('img', { hidden: true })).toBeInTheDocument();
|
||
|
});
|
||
|
|
||
|
it('renders expected children', () => {
|
||
|
setUp();
|
||
|
expect(screen.getByText('the children')).toBeInTheDocument();
|
||
|
});
|
||
|
});
|