shlink-web-client/test/utils/table/TableOrderIcon.test.tsx

38 lines
1.2 KiB
TypeScript
Raw Normal View History

import { render } from '@testing-library/react';
2023-02-18 10:40:37 +01:00
import type { OrderDir } from '../../../src/utils/helpers/ordering';
2023-02-18 11:11:01 +01:00
import { TableOrderIcon } from '../../../src/utils/table/TableOrderIcon';
2021-11-06 22:46:40 +01:00
describe('<TableOrderIcon />', () => {
const setUp = (field: string, currentDir?: OrderDir, className?: string) => render(
<TableOrderIcon currentOrder={{ dir: currentDir, field: 'foo' }} field={field} className={className} />,
);
2021-11-06 22:46:40 +01:00
it.each([
2022-03-26 12:17:42 +01:00
['foo', undefined],
['bar', 'DESC' as OrderDir],
['bar', 'ASC' as OrderDir],
2021-11-06 22:46:40 +01:00
])('renders empty when not all conditions are met', (field, dir) => {
const { container } = setUp(field, dir);
expect(container.firstChild).toBeNull();
2021-11-06 22:46:40 +01:00
});
it.each([
['DESC' as OrderDir],
['ASC' as OrderDir],
])('renders an icon when all conditions are met', (dir) => {
const { container } = setUp('foo', dir);
2021-11-06 22:46:40 +01:00
expect(container.firstChild).not.toBeNull();
expect(container.firstChild).toMatchSnapshot();
2021-11-06 22:46:40 +01:00
});
it.each([
2022-03-26 12:17:42 +01:00
[undefined, 'ms-1'],
['foo', 'foo'],
['bar', 'bar'],
2021-11-06 22:46:40 +01:00
])('renders expected classname', (className, expectedClassName) => {
const { container } = setUp('foo', 'ASC', className);
expect(container.firstChild).toHaveClass(expectedClassName);
2021-11-06 22:46:40 +01:00
});
});