2020-09-04 19:33:16 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
2018-09-08 13:28:40 +02:00
|
|
|
import { identity } from 'ramda';
|
2020-09-04 19:33:16 +02:00
|
|
|
import { Mock } from 'ts-mockery';
|
2021-03-14 12:49:12 +01:00
|
|
|
import createShortUrlVisits, { ShortUrlVisitsProps } from '../../src/visits/ShortUrlVisits';
|
2020-05-10 19:37:00 +02:00
|
|
|
import ShortUrlVisitsHeader from '../../src/visits/ShortUrlVisitsHeader';
|
2020-09-04 19:33:16 +02:00
|
|
|
import { ShortUrlVisits as ShortUrlVisitsState } from '../../src/visits/reducers/shortUrlVisits';
|
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 VisitsStats from '../../src/visits/VisitsStats';
|
2020-09-06 19:41:15 +02:00
|
|
|
import { MercureBoundProps } from '../../src/mercure/helpers/boundToMercureHub';
|
2021-03-14 12:49:12 +01:00
|
|
|
import { VisitsExporter } from '../../src/visits/services/VisitsExporter';
|
2018-09-08 13:28:40 +02:00
|
|
|
|
2022-02-07 22:17:57 +01:00
|
|
|
jest.mock('react-router-dom', () => ({
|
|
|
|
...jest.requireActual('react-router-dom'),
|
|
|
|
useNavigate: jest.fn().mockReturnValue(jest.fn()),
|
|
|
|
useLocation: jest.fn().mockReturnValue({ search: '' }),
|
|
|
|
useParams: jest.fn().mockReturnValue({ shortCode: 'abc123' }),
|
|
|
|
}));
|
|
|
|
|
2018-09-08 13:28:40 +02:00
|
|
|
describe('<ShortUrlVisits />', () => {
|
2020-09-04 19:33:16 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
2019-04-19 12:41:59 +02:00
|
|
|
const getShortUrlVisitsMock = jest.fn();
|
2021-03-14 12:49:12 +01:00
|
|
|
const ShortUrlVisits = createShortUrlVisits(Mock.all<VisitsExporter>());
|
2018-09-08 13:28:40 +02:00
|
|
|
|
2020-05-10 17:49:55 +02:00
|
|
|
beforeEach(() => {
|
2018-09-08 13:28:40 +02:00
|
|
|
wrapper = shallow(
|
2018-12-18 14:32:02 +01:00
|
|
|
<ShortUrlVisits
|
2020-09-04 19:33:16 +02:00
|
|
|
{...Mock.all<ShortUrlVisitsProps>()}
|
2020-09-12 08:52:03 +02:00
|
|
|
{...Mock.of<MercureBoundProps>({ mercureInfo: {} })}
|
2018-09-08 13:28:40 +02:00
|
|
|
getShortUrlDetail={identity}
|
|
|
|
getShortUrlVisits={getShortUrlVisitsMock}
|
2020-09-04 19:33:16 +02:00
|
|
|
shortUrlVisits={Mock.of<ShortUrlVisitsState>({ loading: true, visits: [] })}
|
|
|
|
shortUrlDetail={Mock.all<ShortUrlDetail>()}
|
2020-09-05 08:49:18 +02:00
|
|
|
cancelGetShortUrlVisits={() => {}}
|
2020-08-22 08:10:31 +02:00
|
|
|
/>,
|
2020-09-06 19:41:15 +02:00
|
|
|
).dive(); // Dive is needed as this component is wrapped in a HOC
|
2018-09-08 13:28:40 +02:00
|
|
|
});
|
|
|
|
|
2022-02-07 22:17:57 +01:00
|
|
|
afterEach(jest.clearAllMocks);
|
2020-05-10 17:49:55 +02:00
|
|
|
afterEach(() => wrapper.unmount());
|
2019-01-09 20:11:22 +01:00
|
|
|
|
2020-05-10 17:49:55 +02:00
|
|
|
it('renders visit stats and visits header', () => {
|
|
|
|
const visitStats = wrapper.find(VisitsStats);
|
2020-05-10 19:37:00 +02:00
|
|
|
const visitHeader = wrapper.find(ShortUrlVisitsHeader);
|
2019-01-09 20:11:22 +01:00
|
|
|
|
2020-05-10 17:49:55 +02:00
|
|
|
expect(visitStats).toHaveLength(1);
|
2022-02-05 16:37:01 +01:00
|
|
|
expect(visitStats.prop('isOrphanVisits')).not.toBeDefined();
|
2020-05-10 17:49:55 +02:00
|
|
|
expect(visitHeader).toHaveLength(1);
|
2019-01-09 20:11:22 +01:00
|
|
|
});
|
2018-09-08 13:28:40 +02:00
|
|
|
});
|