2022-02-05 10:04:34 +01:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
|
|
|
import { ReactNode } from 'react';
|
|
|
|
import { Card, CardText, CardTitle } from 'reactstrap';
|
|
|
|
import { Link } from 'react-router-dom';
|
2022-02-05 10:46:46 +01:00
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
2022-02-05 10:04:34 +01:00
|
|
|
import { HighlightCard, HighlightCardProps } from '../../../src/servers/helpers/HighlightCard';
|
|
|
|
|
|
|
|
describe('<HighlightCard />', () => {
|
|
|
|
let wrapper: ShallowWrapper;
|
|
|
|
const createWrapper = (props: HighlightCardProps & { children?: ReactNode }) => {
|
|
|
|
wrapper = shallow(<HighlightCard {...props} />);
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
|
|
|
afterEach(() => wrapper?.unmount());
|
|
|
|
|
2022-02-05 13:37:49 +01:00
|
|
|
it.each([
|
|
|
|
[ undefined ],
|
|
|
|
[ false ],
|
|
|
|
])('renders expected components', (link) => {
|
|
|
|
const wrapper = createWrapper({ title: 'foo', link: link as undefined | false });
|
2022-02-05 10:04:34 +01:00
|
|
|
|
|
|
|
expect(wrapper.find(Card)).toHaveLength(1);
|
|
|
|
expect(wrapper.find(CardTitle)).toHaveLength(1);
|
|
|
|
expect(wrapper.find(CardText)).toHaveLength(1);
|
2022-02-05 10:46:46 +01:00
|
|
|
expect(wrapper.find(FontAwesomeIcon)).toHaveLength(0);
|
2022-02-05 10:04:34 +01:00
|
|
|
expect(wrapper.prop('tag')).not.toEqual(Link);
|
|
|
|
expect(wrapper.prop('to')).not.toBeDefined();
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ 'foo' ],
|
|
|
|
[ 'bar' ],
|
|
|
|
[ 'baz' ],
|
|
|
|
])('renders provided title', (title) => {
|
|
|
|
const wrapper = createWrapper({ title });
|
|
|
|
const cardTitle = wrapper.find(CardTitle);
|
|
|
|
|
|
|
|
expect(cardTitle.html()).toContain(`>${title}<`);
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ 'foo' ],
|
|
|
|
[ 'bar' ],
|
|
|
|
[ 'baz' ],
|
|
|
|
])('renders provided children', (children) => {
|
|
|
|
const wrapper = createWrapper({ title: 'foo', children });
|
|
|
|
const cardText = wrapper.find(CardText);
|
|
|
|
|
|
|
|
expect(cardText.html()).toContain(`>${children}<`);
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ 'foo' ],
|
|
|
|
[ 'bar' ],
|
|
|
|
[ 'baz' ],
|
|
|
|
])('adds extra props when a link is provided', (link) => {
|
|
|
|
const wrapper = createWrapper({ title: 'foo', link });
|
|
|
|
|
2022-02-05 10:46:46 +01:00
|
|
|
expect(wrapper.find(FontAwesomeIcon)).toHaveLength(1);
|
2022-02-05 10:04:34 +01:00
|
|
|
expect(wrapper.prop('tag')).toEqual(Link);
|
|
|
|
expect(wrapper.prop('to')).toEqual(link);
|
|
|
|
});
|
|
|
|
});
|