import { mount } from '@vue/test-utils'; import Mentions from '..'; import focusTest from '../../../tests/shared/focusTest'; import { sleep } from '../../../tests/utils'; const { getMentions } = Mentions; function $$(className) { return document.body.querySelectorAll(className); } function triggerInput(wrapper, text = '') { wrapper.find('textarea').element.value = text; wrapper.find('textarea').element.selectionStart = text.length; wrapper.find('textarea').trigger('keydown'); wrapper.find('textarea').trigger('change'); wrapper.find('textarea').trigger('keyup'); } describe('Mentions', () => { beforeEach(() => { document.body.innerHTML = ''; }); it('getMentions', () => { const mentions = getMentions('@light #bamboo cat', { prefix: ['@', '#'] }); expect(mentions).toEqual([ { prefix: '@', value: 'light', }, { prefix: '#', value: 'bamboo', }, ]); }); fit('focus', async () => { const onFocus = jest.fn(); const onBlur = jest.fn(); const wrapper = mount( { render() { return ; }, }, { sync: false, attachTo: 'body' }, ); await sleep(); wrapper.find('textarea').trigger('focus'); await sleep(); expect(wrapper.find('.ant-mentions').classes('ant-mentions-focused')).toBeTruthy(); expect(onFocus).toHaveBeenCalled(); wrapper.find('textarea').trigger('blur'); await sleep(500); expect(wrapper.classes()).not.toContain('ant-mentions-focused'); expect(onBlur).toHaveBeenCalled(); }); it('loading', async () => { const wrapper = mount( { render() { return ; }, }, { sync: false, attachTo: 'body' }, ); await sleep(500); triggerInput(wrapper, '@'); await sleep(500); expect($$('.ant-mentions-dropdown-menu-item').length).toBeTruthy(); expect($$('.ant-spin')).toBeTruthy(); }); focusTest(Mentions); });