2
0
mirror of https://github.com/iconify/iconify.git synced 2025-01-05 15:02:09 +00:00
iconify/components/react/tests/offline/20-attributes.test.js

86 lines
2.0 KiB
JavaScript
Raw Normal View History

import React from 'react';
2021-05-01 20:39:56 +00:00
import { Icon, InlineIcon } from '../../dist/offline';
import renderer from 'react-test-renderer';
const iconData = {
2022-04-13 06:55:07 +00:00
body: '<path d="M4 19h16v2H4zm5-4h11v2H9zm-5-4h16v2H4zm0-8h16v2H4zm5 4h11v2H9z" fill="currentColor"/>',
width: 24,
height: 24,
};
describe('Passing attributes', () => {
test('title', () => {
const component = renderer.create(
<Icon icon={iconData} title="Icon!" />
);
const tree = component.toJSON();
expect(tree.props.title).toStrictEqual('Icon!');
});
test('aria-hidden', () => {
2021-04-30 09:51:56 +00:00
// dashes, string value
const component = renderer.create(
<InlineIcon icon={iconData} aria-hidden="false" />
);
const tree = component.toJSON();
expect(tree.props['aria-hidden']).toStrictEqual(void 0);
});
test('ariaHidden', () => {
2021-04-30 09:51:56 +00:00
// camelCase, boolean value
const component = renderer.create(
2021-04-30 09:51:56 +00:00
<InlineIcon icon={iconData} ariaHidden={false} />
);
const tree = component.toJSON();
expect(tree.props['aria-hidden']).toStrictEqual(void 0);
});
test('style', () => {
const component = renderer.create(
<InlineIcon
icon={iconData}
style={{ verticalAlign: '0', color: 'red' }}
/>
);
const tree = component.toJSON();
expect(tree.props.style).toMatchObject({
verticalAlign: '0',
color: 'red',
});
});
test('color', () => {
const component = renderer.create(<Icon icon={iconData} color="red" />);
const tree = component.toJSON();
expect(tree.props.style).toMatchObject({
color: 'red',
});
});
test('color with style', () => {
const component = renderer.create(
<Icon icon={iconData} color="red" style={{ color: 'green' }} />
);
const tree = component.toJSON();
2022-04-13 06:55:07 +00:00
// `style` overrides `color`
expect(tree.props.style).toMatchObject({
2022-04-13 06:55:07 +00:00
color: 'green',
});
});
test('attributes that cannot change', () => {
const component = renderer.create(
2022-04-30 20:12:34 +00:00
<InlineIcon icon={iconData} viewBox="0 0 0 0" />
);
const tree = component.toJSON();
expect(tree.props.viewBox).toStrictEqual('0 0 24 24');
});
});