2022-05-06 21:24:16 +02:00
|
|
|
import { render } from '@testing-library/react';
|
2023-02-18 10:40:37 +01:00
|
|
|
import type { ShlinkLogoProps } from '../../../src/common/img/ShlinkLogo';
|
|
|
|
import { ShlinkLogo } from '../../../src/common/img/ShlinkLogo';
|
2020-12-20 12:17:12 +01:00
|
|
|
import { MAIN_COLOR } from '../../../src/utils/theme';
|
|
|
|
|
|
|
|
describe('<ShlinkLogo />', () => {
|
2022-05-06 21:24:16 +02:00
|
|
|
const setUp = (props: ShlinkLogoProps) => render(<ShlinkLogo {...props} />);
|
2020-12-20 12:17:12 +01:00
|
|
|
|
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[undefined, MAIN_COLOR],
|
|
|
|
['red', 'red'],
|
|
|
|
['white', 'white'],
|
2020-12-20 12:17:12 +01:00
|
|
|
])('renders expected color', (color, expectedColor) => {
|
2022-05-06 21:24:16 +02:00
|
|
|
const { container } = setUp({ color });
|
|
|
|
expect(container.querySelector('g')).toHaveAttribute('fill', expectedColor);
|
2020-12-20 12:17:12 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[undefined, undefined],
|
|
|
|
['foo', 'foo'],
|
|
|
|
['bar', 'bar'],
|
2020-12-20 12:17:12 +01:00
|
|
|
])('renders expected class', (className, expectedClassName) => {
|
2022-05-06 21:24:16 +02:00
|
|
|
const { container } = setUp({ className });
|
2020-12-20 12:17:12 +01:00
|
|
|
|
2022-05-06 21:24:16 +02:00
|
|
|
if (expectedClassName) {
|
|
|
|
expect(container.firstChild).toHaveAttribute('class', expectedClassName);
|
|
|
|
} else {
|
|
|
|
expect(container.firstChild).not.toHaveAttribute('class');
|
|
|
|
}
|
2020-12-20 12:17:12 +01:00
|
|
|
});
|
|
|
|
});
|