diff --git a/components/mentions/__tests__/__snapshots__/demo.test.js.snap b/components/mentions/__tests__/__snapshots__/demo.test.ts.snap similarity index 100% rename from components/mentions/__tests__/__snapshots__/demo.test.js.snap rename to components/mentions/__tests__/__snapshots__/demo.test.ts.snap diff --git a/components/mentions/__tests__/__snapshots__/index.test.js.snap b/components/mentions/__tests__/__snapshots__/index.test.tsx.snap similarity index 100% rename from components/mentions/__tests__/__snapshots__/index.test.js.snap rename to components/mentions/__tests__/__snapshots__/index.test.tsx.snap diff --git a/components/mentions/__tests__/demo.test.js b/components/mentions/__tests__/demo.test.ts similarity index 100% rename from components/mentions/__tests__/demo.test.js rename to components/mentions/__tests__/demo.test.ts diff --git a/components/mentions/__tests__/index.test.js b/components/mentions/__tests__/index.test.js deleted file mode 100644 index 57e9abf289b8..000000000000 --- a/components/mentions/__tests__/index.test.js +++ /dev/null @@ -1,97 +0,0 @@ -import { mount } from 'enzyme'; -import React from 'react'; -import Mentions from '..'; -import focusTest from '../../../tests/shared/focusTest'; -import mountTest from '../../../tests/shared/mountTest'; -import rtlTest from '../../../tests/shared/rtlTest'; -import { act } from '../../../tests/utils'; - -const { getMentions } = Mentions; - -function simulateInput(wrapper, text, keyEvent) { - const lastChar = text[text.length - 1]; - const myKeyEvent = keyEvent || { - which: lastChar.charCodeAt(0), - key: lastChar, - target: { - value: text, - selectionStart: text.length, - }, - }; - - wrapper.find('textarea').simulate('keyDown', myKeyEvent); - - const textareaInstance = wrapper.find('textarea').instance(); - textareaInstance.value = text; - textareaInstance.selectionStart = text.length; - textareaInstance.selectionStart = text.length; - - if (!keyEvent) { - wrapper.find('textarea').simulate('change', { - target: { value: text }, - }); - } - - wrapper.find('textarea').simulate('keyUp', myKeyEvent); - wrapper.update(); -} - -describe('Mentions', () => { - beforeAll(() => { - jest.useFakeTimers(); - }); - - afterAll(() => { - jest.useRealTimers(); - }); - - it('getMentions', () => { - const mentions = getMentions('@light #bamboo cat', { prefix: ['@', '#'] }); - expect(mentions).toEqual([ - { - prefix: '@', - value: 'light', - }, - { - prefix: '#', - value: 'bamboo', - }, - ]); - }); - - it('focus', () => { - const onFocus = jest.fn(); - const onBlur = jest.fn(); - - const wrapper = mount(); - wrapper.find('textarea').simulate('focus'); - expect(wrapper.find('.ant-mentions').hasClass('ant-mentions-focused')).toBeTruthy(); - expect(onFocus).toHaveBeenCalled(); - - wrapper.find('textarea').simulate('blur'); - act(() => { - jest.runAllTimers(); - }); - wrapper.update(); - expect(wrapper.find('.ant-mentions').hasClass('ant-mentions-focused')).toBeFalsy(); - expect(onBlur).toHaveBeenCalled(); - }); - - focusTest(Mentions, { refFocus: true }); - mountTest(Mentions); - rtlTest(Mentions); - - it('loading', () => { - const wrapper = mount(); - simulateInput(wrapper, '@'); - expect(wrapper.find('li.ant-mentions-dropdown-menu-item').length).toBe(1); - expect(wrapper.find('.ant-spin').length).toBeTruthy(); - }); - - it('notFoundContent', () => { - const wrapper = mount(} />); - simulateInput(wrapper, '@'); - expect(wrapper.find('li.ant-mentions-dropdown-menu-item').length).toBe(1); - expect(wrapper.find('.bamboo-light').length).toBeTruthy(); - }); -}); diff --git a/components/mentions/__tests__/index.test.tsx b/components/mentions/__tests__/index.test.tsx new file mode 100644 index 000000000000..320336eafd09 --- /dev/null +++ b/components/mentions/__tests__/index.test.tsx @@ -0,0 +1,87 @@ +import React from 'react'; +import Mentions from '..'; +import focusTest from '../../../tests/shared/focusTest'; +import mountTest from '../../../tests/shared/mountTest'; +import rtlTest from '../../../tests/shared/rtlTest'; +import { act, render, fireEvent } from '../../../tests/utils'; + +const { getMentions } = Mentions; + +function simulateInput(wrapper: ReturnType, text: string, keyEvent?: Event): void { + const lastChar = text[text.length - 1]; + const myKeyEvent = keyEvent || { + which: lastChar.charCodeAt(0), + key: lastChar, + target: { + value: text, + selectionStart: text.length, + }, + }; + + fireEvent.keyDown(wrapper.container.querySelector('textarea')!, myKeyEvent); + + const textareaInstance = wrapper.container.querySelector('textarea'); + + if (textareaInstance) { + textareaInstance.value = text; + textareaInstance.selectionStart = text.length; + textareaInstance.selectionStart = text.length; + } + + if (!keyEvent) { + fireEvent.change(wrapper.container.querySelector('textarea')!, { target: { value: text } }); + } + fireEvent.keyUp(wrapper.container.querySelector('textarea')!, myKeyEvent); +} + +describe('Mentions', () => { + beforeAll(() => { + jest.useFakeTimers(); + }); + + afterAll(() => { + jest.useRealTimers(); + }); + + it('getMentions', () => { + const mentions = getMentions('@light #bamboo cat', { prefix: ['@', '#'] }); + expect(mentions).toEqual([ + { prefix: '@', value: 'light' }, + { prefix: '#', value: 'bamboo' }, + ]); + }); + + it('focus', () => { + const onFocus = jest.fn(); + const onBlur = jest.fn(); + + const { container } = render(); + fireEvent.focus(container.querySelector('textarea')!); + expect(container.querySelector('.ant-mentions')).toHaveClass('ant-mentions-focused'); + expect(onFocus).toHaveBeenCalled(); + fireEvent.blur(container.querySelector('textarea')!); + act(() => { + jest.runAllTimers(); + }); + expect(container.querySelector('.ant-mentions')).not.toHaveClass('ant-mentions-focused'); + expect(onBlur).toHaveBeenCalled(); + }); + + focusTest(Mentions, { refFocus: true }); + mountTest(Mentions); + rtlTest(Mentions); + + it('loading', () => { + const wrapper = render(); + simulateInput(wrapper, '@'); + expect(wrapper.container.querySelectorAll('li.ant-mentions-dropdown-menu-item').length).toBe(1); + expect(wrapper.container.querySelectorAll('.ant-spin').length).toBeTruthy(); + }); + + it('notFoundContent', () => { + const wrapper = render(} />); + simulateInput(wrapper, '@'); + expect(wrapper.container.querySelectorAll('li.ant-mentions-dropdown-menu-item').length).toBe(1); + expect(wrapper.container.querySelectorAll('.bamboo-light').length).toBeTruthy(); + }); +});