import React from 'react'; import dayjs from 'dayjs'; import MockDate from 'mockdate'; import type { CountdownProps } from '..'; import Statistic from '..'; import mountTest from '../../../tests/shared/mountTest'; import rtlTest from '../../../tests/shared/rtlTest'; import { fireEvent, render, waitFakeTimer } from '../../../tests/utils'; import { formatTimeStr } from '../utils'; describe('Statistic', () => { mountTest(Statistic); mountTest(Statistic.Countdown); rtlTest(Statistic); beforeAll(() => { MockDate.set(dayjs('2018-11-28 00:00:00').valueOf()); }); afterAll(() => { MockDate.reset(); }); it('`-` is not a number', () => { const { container } = render(); expect(container.querySelector('.ant-statistic-content')!.textContent).toEqual('-'); }); it('customize formatter', () => { const formatter = jest.fn(() => 93); const { container } = render(); expect(formatter).toHaveBeenCalledWith(1128); expect(container.querySelector('.ant-statistic-content-value')!.textContent).toEqual('93'); }); it('groupSeparator', () => { const { container } = render(); expect(container.querySelector('.ant-statistic-content-value')!.textContent).toEqual( '1__TEST__128', ); }); it('not a number', () => { const { container } = render(); expect(container.querySelector('.ant-statistic-content-value')!.textContent).toEqual('bamboo'); }); it('support negative number', () => { const { asFragment } = render( , ); expect(asFragment().firstChild).toMatchSnapshot(); }); it('allow negative precision', () => { [ [-1, -1112893.1212, '-1,112,893'], [-2, -1112893.1212, '-1,112,893'], [-3, -1112893.1212, '-1,112,893'], [-1, -1112893, '-1,112,893'], [-1, 1112893, '1,112,893'], ].forEach(([precision, value, expectValue]) => { const { container } = render(); expect(container.querySelector('.ant-statistic-content-value-int')!.textContent).toEqual( expectValue, ); expect(container.querySelectorAll('.ant-statistic-content-value-decimal').length).toBe(0); }); }); it('loading with skeleton', async () => { let loading = false; const { container, rerender } = render( , ); expect(container.querySelectorAll('.ant-skeleton')).toHaveLength(0); expect(container.querySelectorAll('.ant-statistic-content')).toHaveLength(1); loading = true; rerender(); expect(container.querySelectorAll('.ant-skeleton')).toHaveLength(1); expect(container.querySelectorAll('.ant-statistic-content')).toHaveLength(0); }); it('data attrs', () => { const { container } = render( , ); expect(container.querySelector('.ant-statistic')!.getAttribute('data-abc')).toEqual('1'); expect(container.querySelector('.ant-statistic')!.getAttribute('aria-label')).toEqual('2'); expect(container.querySelector('.ant-statistic')!.getAttribute('role')).toEqual('status'); const { container: countdownContainer } = render( , ); expect(countdownContainer.querySelector('.ant-statistic')!.getAttribute('data-xyz')).toEqual( 'x', ); expect(countdownContainer.querySelector('.ant-statistic')!.getAttribute('aria-label')).toEqual( 'y', ); expect(countdownContainer.querySelector('.ant-statistic')!.getAttribute('role')).toEqual( 'contentinfo', ); }); describe('Countdown', () => { it('render correctly', () => { const now = dayjs() .add(2, 'd') .add(11, 'h') .add(28, 'm') .add(9, 's') .add(3, 'ms') .toISOString(); [ ['H:m:s', '59:28:9'], ['HH:mm:ss', '59:28:09'], ['HH:mm:ss:SSS', '59:28:09:003'], ['DD-HH:mm:ss', '02-11:28:09'], ].forEach(([format, value]) => { const { container } = render(); expect(container.querySelector('.ant-statistic-content-value')!.textContent).toEqual(value); }); }); it('time going', async () => { jest.useFakeTimers(); const now = Date.now() + 1000; const onFinish = jest.fn(); const { unmount } = render(); await waitFakeTimer(10); unmount(); expect(onFinish).not.toHaveBeenCalled(); jest.clearAllTimers(); jest.useRealTimers(); }); it('responses hover events', () => { const onMouseEnter = jest.fn(); const onMouseLeave = jest.fn(); const { container } = render( , ); fireEvent.mouseEnter(container.firstChild!); expect(onMouseEnter).toHaveBeenCalled(); fireEvent.mouseLeave(container.firstChild!); expect(onMouseLeave).toHaveBeenCalled(); }); it('responses hover events for Countdown', () => { const onMouseEnter = jest.fn(); const onMouseLeave = jest.fn(); const { container } = render( , ); fireEvent.mouseEnter(container.firstChild!); expect(onMouseEnter).toHaveBeenCalled(); fireEvent.mouseLeave(container.firstChild!); expect(onMouseLeave).toHaveBeenCalled(); }); describe('time onchange', () => { it("called if time has't passed", async () => { jest.useFakeTimers(); const deadline = Date.now() + 10 * 1000; let remainingTime; const onChange: CountdownProps['onChange'] = (value) => { remainingTime = value; }; render(); // container.update(); await waitFakeTimer(100); expect(remainingTime).toBeGreaterThan(0); jest.clearAllTimers(); jest.useRealTimers(); }); }); describe('time finished', () => { it('not call if time already passed', () => { const now = Date.now() - 1000; const onFinish = jest.fn(); render(); expect(onFinish).not.toHaveBeenCalled(); }); it('called if finished', async () => { jest.useFakeTimers(); const now = Date.now() + 10; const onFinish = jest.fn(); render(); await waitFakeTimer(); expect(onFinish).toHaveBeenCalled(); jest.clearAllTimers(); jest.useRealTimers(); }); }); }); describe('utils', () => { it('format should support escape', () => { expect(formatTimeStr(1000 * 60 * 60 * 24, 'D [Day]')).toBe('1 Day'); }); }); });