2022-06-10 17:28:55 +08:00
|
|
|
import * as React from 'react';
|
2022-02-09 18:07:52 +08:00
|
|
|
import KeyCode from 'rc-util/lib/KeyCode';
|
2022-06-09 18:09:43 +08:00
|
|
|
import { fireEvent, render } from '../../../tests/utils';
|
2022-02-09 18:07:52 +08:00
|
|
|
import Paragraph from '../Paragraph';
|
|
|
|
|
|
|
|
test('Callback on enter key is triggered', () => {
|
|
|
|
const onEditStart = jest.fn();
|
|
|
|
const onCopy = jest.fn();
|
|
|
|
|
2022-06-09 18:09:43 +08:00
|
|
|
const { container: wrapper } = render(
|
2022-02-09 18:07:52 +08:00
|
|
|
<Paragraph
|
|
|
|
copyable={{
|
|
|
|
onCopy,
|
|
|
|
}}
|
|
|
|
editable={{
|
|
|
|
onStart: onEditStart,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
test
|
|
|
|
</Paragraph>,
|
|
|
|
);
|
|
|
|
const timer: any = 9527;
|
|
|
|
jest.spyOn(window, 'setTimeout').mockReturnValue(timer);
|
|
|
|
jest.spyOn(window, 'clearTimeout');
|
|
|
|
// must copy first, because editing button will hide copy button
|
2022-06-09 18:09:43 +08:00
|
|
|
fireEvent.keyUp(wrapper.querySelectorAll('.ant-typography-copy')[0], { keyCode: KeyCode.ENTER });
|
|
|
|
fireEvent.keyUp(wrapper.querySelectorAll('.anticon-edit')[0], { keyCode: KeyCode.ENTER });
|
2022-02-09 18:07:52 +08:00
|
|
|
|
|
|
|
expect(onEditStart.mock.calls.length).toBe(1);
|
|
|
|
expect(onCopy.mock.calls.length).toBe(1);
|
|
|
|
jest.restoreAllMocks();
|
|
|
|
});
|