2020-09-05 08:49:18 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
2020-05-10 19:37:00 +02:00
|
|
|
import { ExternalLink } from 'react-external-link';
|
2020-09-05 08:49:18 +02:00
|
|
|
import { Mock } from 'ts-mockery';
|
2020-05-10 19:37:00 +02:00
|
|
|
import ShortUrlVisitsHeader from '../../src/visits/ShortUrlVisitsHeader';
|
2021-03-05 16:04:02 +01:00
|
|
|
import { ShortUrlDetail } from '../../src/short-urls/reducers/shortUrlDetail';
|
2020-09-05 08:49:18 +02:00
|
|
|
import { ShortUrlVisits } from '../../src/visits/reducers/shortUrlVisits';
|
2021-06-24 20:13:06 +02:00
|
|
|
import { Time } from '../../src/utils/Time';
|
2020-05-10 19:37:00 +02:00
|
|
|
|
|
|
|
describe('<ShortUrlVisitsHeader />', () => {
|
2020-09-05 08:49:18 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
2021-03-05 15:44:15 +01:00
|
|
|
const dateCreated = '2018-01-01T10:00:00+01:00';
|
|
|
|
const longUrl = 'https://foo.bar/bar/foo';
|
2020-09-05 08:49:18 +02:00
|
|
|
const shortUrlVisits = Mock.of<ShortUrlVisits>({
|
2020-05-10 19:37:00 +02:00
|
|
|
visits: [{}, {}, {}],
|
2020-09-05 08:49:18 +02:00
|
|
|
});
|
2020-05-10 19:37:00 +02:00
|
|
|
const goBack = jest.fn();
|
2021-03-05 15:44:15 +01:00
|
|
|
const createWrapper = (title?: string | null) => {
|
|
|
|
const shortUrlDetail = Mock.of<ShortUrlDetail>({
|
|
|
|
shortUrl: {
|
|
|
|
shortUrl: 'https://doma.in/abc123',
|
|
|
|
longUrl,
|
|
|
|
dateCreated,
|
|
|
|
title,
|
|
|
|
},
|
|
|
|
loading: false,
|
|
|
|
});
|
2020-05-10 19:37:00 +02:00
|
|
|
|
|
|
|
wrapper = shallow(
|
2020-08-22 08:10:31 +02:00
|
|
|
<ShortUrlVisitsHeader shortUrlDetail={shortUrlDetail} shortUrlVisits={shortUrlVisits} goBack={goBack} />,
|
2020-05-10 19:37:00 +02:00
|
|
|
);
|
2021-03-05 15:44:15 +01:00
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => createWrapper());
|
2020-05-10 19:37:00 +02:00
|
|
|
afterEach(() => wrapper.unmount());
|
|
|
|
|
|
|
|
it('shows when the URL was created', () => {
|
2021-06-24 20:13:06 +02:00
|
|
|
const time = wrapper.find(Time).first();
|
2020-05-10 19:37:00 +02:00
|
|
|
|
2021-06-24 20:13:06 +02:00
|
|
|
expect(time.prop('date')).toEqual(dateCreated);
|
2020-05-10 19:37:00 +02:00
|
|
|
});
|
|
|
|
|
2021-03-05 15:44:15 +01:00
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
[null, longUrl],
|
|
|
|
[undefined, longUrl],
|
|
|
|
['My cool title', 'My cool title'],
|
2021-03-05 15:44:15 +01:00
|
|
|
])('shows the long URL and title', (title, expectedContent) => {
|
|
|
|
const wrapper = createWrapper(title);
|
2020-05-10 19:37:00 +02:00
|
|
|
const longUrlLink = wrapper.find(ExternalLink).last();
|
|
|
|
|
2021-03-05 15:44:15 +01:00
|
|
|
expect(longUrlLink.prop('href')).toEqual(longUrl);
|
|
|
|
expect(longUrlLink.prop('children')).toEqual(expectedContent);
|
2020-05-10 19:37:00 +02:00
|
|
|
});
|
|
|
|
});
|