2020-08-30 09:59:14 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
2020-01-11 19:58:04 +01:00
|
|
|
import { UncontrolledTooltip } from 'reactstrap';
|
2020-08-30 09:59:14 +02:00
|
|
|
import { Mock } from 'ts-mockery';
|
2020-01-11 19:58:04 +01:00
|
|
|
import ShortUrlVisitsCount from '../../../src/short-urls/helpers/ShortUrlVisitsCount';
|
2020-08-30 09:59:14 +02:00
|
|
|
import { ShortUrl } from '../../../src/short-urls/data';
|
2020-01-11 19:58:04 +01:00
|
|
|
|
|
|
|
describe('<ShortUrlVisitsCount />', () => {
|
2020-08-30 09:59:14 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
2020-01-11 19:58:04 +01:00
|
|
|
|
2020-08-30 09:59:14 +02:00
|
|
|
const createWrapper = (visitsCount: number, shortUrl: ShortUrl) => {
|
2020-02-08 09:07:55 +01:00
|
|
|
wrapper = shallow(<ShortUrlVisitsCount visitsCount={visitsCount} shortUrl={shortUrl} />);
|
2020-01-11 19:58:04 +01:00
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
2020-08-30 09:59:14 +02:00
|
|
|
afterEach(() => wrapper?.unmount());
|
2020-01-11 19:58:04 +01:00
|
|
|
|
2020-02-17 18:21:52 +01:00
|
|
|
it.each([ undefined, {}])('just returns visits when no maxVisits is provided', (meta) => {
|
2020-01-11 19:58:04 +01:00
|
|
|
const visitsCount = 45;
|
2020-08-30 09:59:14 +02:00
|
|
|
const wrapper = createWrapper(visitsCount, Mock.of<ShortUrl>({ meta }));
|
2020-01-12 12:08:26 +01:00
|
|
|
const maxVisitsHelper = wrapper.find('.short-urls-visits-count__max-visits-control');
|
2020-01-11 19:58:04 +01:00
|
|
|
const maxVisitsTooltip = wrapper.find(UncontrolledTooltip);
|
|
|
|
|
2020-04-18 10:50:01 +02:00
|
|
|
expect(wrapper.html()).toEqual(
|
2020-08-22 08:10:31 +02:00
|
|
|
`<span><strong class="short-url-visits-count__amount">${visitsCount}</strong></span>`,
|
2020-04-18 10:50:01 +02:00
|
|
|
);
|
2020-01-11 19:58:04 +01:00
|
|
|
expect(maxVisitsHelper).toHaveLength(0);
|
|
|
|
expect(maxVisitsTooltip).toHaveLength(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('displays the maximum amount of visits when present', () => {
|
|
|
|
const visitsCount = 45;
|
|
|
|
const maxVisits = 500;
|
|
|
|
const meta = { maxVisits };
|
2020-08-30 09:59:14 +02:00
|
|
|
const wrapper = createWrapper(visitsCount, Mock.of<ShortUrl>({ meta }));
|
2020-01-12 12:08:26 +01:00
|
|
|
const maxVisitsHelper = wrapper.find('.short-urls-visits-count__max-visits-control');
|
2020-01-11 19:58:04 +01:00
|
|
|
const maxVisitsTooltip = wrapper.find(UncontrolledTooltip);
|
|
|
|
|
|
|
|
expect(wrapper.html()).toContain(`/ ${maxVisits}`);
|
|
|
|
expect(maxVisitsHelper).toHaveLength(1);
|
|
|
|
expect(maxVisitsTooltip).toHaveLength(1);
|
|
|
|
});
|
|
|
|
});
|