import { nextTick, ref } from 'vue' import { mount } from '@vue/test-utils' import { afterEach, describe, expect, it, vi } from 'vitest' import { POPPER_INJECTION_KEY } from '@element-plus/components/popper' import ElTrigger from '../src/trigger.vue' import type { VueWrapper } from '@vue/test-utils' import type { PopperTriggerInstance } from '../src/trigger' const AXIOM = 'rem is the best girl' const popperInjection = { triggerRef: ref(null), popperInstanceRef: ref(null), contentRef: ref(null), } const mountTrigger = (props = {}) => mount({AXIOM}, { global: { provide: { [POPPER_INJECTION_KEY as symbol]: popperInjection, }, }, }) describe('', () => { let wrapper: VueWrapper afterEach(() => { popperInjection.triggerRef.value = null }) describe('rendering', () => { it('should be able to render with children', async () => { wrapper = mountTrigger() await nextTick() expect(popperInjection.triggerRef.value).not.toBeNull() expect(wrapper.text()).toEqual(AXIOM) }) it('should be able to render for virtual ref', async () => { wrapper = mountTrigger({ virtualTriggering: true, }) await nextTick() expect(wrapper.text()).not.toEqual(AXIOM) const virtualRef = document.createElement('div') await wrapper.setProps({ virtualRef, }) expect(popperInjection.triggerRef.value).toStrictEqual }) }) describe('can attach handlers', () => { it('should be able to attach handlers to the trigger', async () => { const onClick = vi.fn() const virtualRef = document.createElement('div') wrapper = mountTrigger({ onClick, virtualTriggering: true, virtualRef, }) await nextTick() expect(onClick).not.toHaveBeenCalled() const evt = new MouseEvent('click') virtualRef.dispatchEvent(evt) await nextTick() expect(onClick).toHaveBeenCalled() }) }) })