2023-03-18 12:55:07 +03:00
|
|
|
import { screen, waitFor } from '@testing-library/react';
|
2023-04-13 22:48:29 +03:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2022-05-02 20:19:47 +03:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-07-24 21:14:59 +03:00
|
|
|
import type { MercureInfo } from '../../shlink-web-component/mercure/reducers/mercureInfo';
|
|
|
|
import { Overview as overviewCreator } from '../../shlink-web-component/overview/Overview';
|
2020-12-08 19:51:49 +03:00
|
|
|
import { prettify } from '../../src/utils/helpers/numbers';
|
2023-03-18 12:55:07 +03:00
|
|
|
import { renderWithEvents } from '../__helpers__/setUpTest';
|
2020-12-08 19:51:49 +03:00
|
|
|
|
|
|
|
describe('<Overview />', () => {
|
2022-05-02 20:19:47 +03:00
|
|
|
const ShortUrlsTable = () => <>ShortUrlsTable</>;
|
|
|
|
const CreateShortUrl = () => <>CreateShortUrl</>;
|
2023-05-27 12:57:26 +03:00
|
|
|
const listShortUrls = vi.fn();
|
|
|
|
const listTags = vi.fn();
|
|
|
|
const loadVisitsOverview = vi.fn();
|
2022-05-02 20:19:47 +03:00
|
|
|
const Overview = overviewCreator(ShortUrlsTable, CreateShortUrl);
|
2020-12-08 19:51:49 +03:00
|
|
|
const shortUrls = {
|
|
|
|
pagination: { totalItems: 83710 },
|
|
|
|
};
|
|
|
|
const serverId = '123';
|
2023-03-18 12:55:07 +03:00
|
|
|
const setUp = (loading = false, excludeBots = false) => renderWithEvents(
|
2022-05-02 20:19:47 +03:00
|
|
|
<MemoryRouter>
|
|
|
|
<Overview
|
|
|
|
listShortUrls={listShortUrls}
|
|
|
|
listTags={listTags}
|
|
|
|
loadVisitsOverview={loadVisitsOverview}
|
2023-04-13 22:48:29 +03:00
|
|
|
shortUrlsList={fromPartial({ loading, shortUrls })}
|
|
|
|
tagsList={fromPartial({ loading, tags: ['foo', 'bar', 'baz'] })}
|
|
|
|
visitsOverview={fromPartial({
|
2023-03-18 12:55:07 +03:00
|
|
|
loading,
|
|
|
|
nonOrphanVisits: { total: 3456, bots: 1000, nonBots: 2456 },
|
|
|
|
orphanVisits: { total: 28, bots: 15, nonBots: 13 },
|
|
|
|
})}
|
2023-04-13 22:48:29 +03:00
|
|
|
selectedServer={fromPartial({ id: serverId })}
|
2023-05-27 12:57:26 +03:00
|
|
|
createNewVisits={vi.fn()}
|
|
|
|
loadMercureInfo={vi.fn()}
|
2023-04-13 22:48:29 +03:00
|
|
|
mercureInfo={fromPartial<MercureInfo>({})}
|
|
|
|
settings={fromPartial({ visits: { excludeBots } })}
|
2022-05-02 20:19:47 +03:00
|
|
|
/>
|
|
|
|
</MemoryRouter>,
|
|
|
|
);
|
2020-12-08 19:51:49 +03:00
|
|
|
|
2021-03-06 19:25:09 +03:00
|
|
|
it('displays loading messages when still loading', () => {
|
2022-05-02 20:19:47 +03:00
|
|
|
setUp(true);
|
|
|
|
expect(screen.getAllByText('Loading...')).toHaveLength(4);
|
2020-12-08 19:51:49 +03:00
|
|
|
});
|
|
|
|
|
2023-03-18 12:55:07 +03:00
|
|
|
it.each([
|
|
|
|
[false, 3456, 28],
|
|
|
|
[true, 2456, 13],
|
|
|
|
])('displays amounts in cards after finishing loading', (excludeBots, expectedVisits, expectedOrphanVisits) => {
|
|
|
|
setUp(false, excludeBots);
|
2022-05-02 20:19:47 +03:00
|
|
|
|
|
|
|
const headingElements = screen.getAllByRole('heading');
|
2020-12-08 19:51:49 +03:00
|
|
|
|
2022-05-02 20:19:47 +03:00
|
|
|
expect(screen.queryByText('Loading...')).not.toBeInTheDocument();
|
|
|
|
expect(headingElements[0]).toHaveTextContent('Visits');
|
2023-03-18 12:55:07 +03:00
|
|
|
expect(headingElements[1]).toHaveTextContent(prettify(expectedVisits));
|
2022-05-02 20:19:47 +03:00
|
|
|
expect(headingElements[2]).toHaveTextContent('Orphan visits');
|
2023-03-18 12:55:07 +03:00
|
|
|
expect(headingElements[3]).toHaveTextContent(prettify(expectedOrphanVisits));
|
2022-05-02 20:19:47 +03:00
|
|
|
expect(headingElements[4]).toHaveTextContent('Short URLs');
|
|
|
|
expect(headingElements[5]).toHaveTextContent(prettify(83710));
|
|
|
|
expect(headingElements[6]).toHaveTextContent('Tags');
|
|
|
|
expect(headingElements[7]).toHaveTextContent(prettify(3));
|
2020-12-08 19:51:49 +03:00
|
|
|
});
|
|
|
|
|
2022-05-02 20:19:47 +03:00
|
|
|
it('nests injected components', () => {
|
|
|
|
setUp();
|
2020-12-08 19:51:49 +03:00
|
|
|
|
2022-05-02 20:19:47 +03:00
|
|
|
expect(screen.queryByText('ShortUrlsTable')).toBeInTheDocument();
|
|
|
|
expect(screen.queryByText('CreateShortUrl')).toBeInTheDocument();
|
2020-12-08 19:51:49 +03:00
|
|
|
});
|
|
|
|
|
2021-03-06 19:25:09 +03:00
|
|
|
it('displays links to other sections', () => {
|
2022-05-02 20:19:47 +03:00
|
|
|
setUp();
|
|
|
|
|
|
|
|
const links = screen.getAllByRole('link');
|
2020-12-08 19:51:49 +03:00
|
|
|
|
2022-05-01 11:50:06 +03:00
|
|
|
expect(links).toHaveLength(5);
|
2022-05-02 20:19:47 +03:00
|
|
|
expect(links[0]).toHaveAttribute('href', `/server/${serverId}/orphan-visits`);
|
|
|
|
expect(links[1]).toHaveAttribute('href', `/server/${serverId}/list-short-urls/1`);
|
|
|
|
expect(links[2]).toHaveAttribute('href', `/server/${serverId}/manage-tags`);
|
|
|
|
expect(links[3]).toHaveAttribute('href', `/server/${serverId}/create-short-url`);
|
|
|
|
expect(links[4]).toHaveAttribute('href', `/server/${serverId}/list-short-urls/1`);
|
2020-12-08 19:51:49 +03:00
|
|
|
});
|
2023-03-18 12:55:07 +03:00
|
|
|
|
|
|
|
it.each([
|
|
|
|
[true],
|
|
|
|
[false],
|
|
|
|
])('displays amounts of bots when hovering visits cards', async (excludeBots) => {
|
|
|
|
const { user } = setUp(false, excludeBots);
|
|
|
|
const expectTooltipToBeInTheDocument = async (tooltip: string) => waitFor(
|
|
|
|
() => expect(screen.getByText(/potential bot visits$/)).toHaveTextContent(tooltip),
|
|
|
|
);
|
|
|
|
|
|
|
|
await user.hover(screen.getByText(/^Visits/));
|
|
|
|
await expectTooltipToBeInTheDocument(`${excludeBots ? 'Plus' : 'Including'} 1,000 potential bot visits`);
|
|
|
|
|
|
|
|
await user.hover(screen.getByText(/^Orphan visits/));
|
|
|
|
await expectTooltipToBeInTheDocument(`${excludeBots ? 'Plus' : 'Including'} 15 potential bot visits`);
|
|
|
|
});
|
2020-12-08 19:51:49 +03:00
|
|
|
});
|