element-plus/packages/components/popper/__tests__/content.spec.ts
jeremywu dd19cae2bc
refactor(components): popper composables (#5035)
* refactor(components): popper composables

- Refactor popper composables

* updates

* updates for tooltip

* Updates for popper. TODO: fix controlled tooltip animation

* Fix controlled mode popper animation issue

* Add new feature for customizing tooltip theme

* Fix popover and popconfirm error

* - Add Collection component for wrapping a collection of component
- Add FocusTrap component for trap focus for popups
- Add RovingFocus component for roving focus component type
- Adjust dropdown component based on these newly added components
- Add popper-trigger component for placing the trigger
- TODO: Finish current dropdown component, and all component's tests plus documents

* Refactor popper

* Complete organizing popper

* Almost finish dropdown

* Update popper tests

* update only-child test

* Finish focus trap component test

* Finish tooltip content test

* Finish tooltip trigger tests

* Finish tooltip tests

* finish tests for Collection and RovingFocusGroup

* Fix test cases for timeselect & select & popover

* Fix popover, popconfirm, menu bug and test cases

* Fix select-v2 test error caused by updating popper

* Fix date-picker test issue for updating popper

* fix test cases

* Fix eslint

* Rebase dev & fix tests

* Remove unused code
2022-01-04 09:15:15 +08:00

136 lines
3.6 KiB
TypeScript

import { ref, nextTick } from 'vue'
import { shallowMount } from '@vue/test-utils'
import ElContent from '../src/content.vue'
import { POPPER_INJECTION_KEY } from '../src/tokens'
const AXIOM = 'rem is the best girl'
const popperInjection = {
triggerRef: ref(null),
popperInstanceRef: ref(null),
contentRef: ref(null),
}
const mountContent = (props = {}) =>
shallowMount(ElContent, {
props,
slots: {
default: () => AXIOM,
},
global: {
provide: {
[POPPER_INJECTION_KEY as symbol]: popperInjection,
},
},
})
describe('<ElPopperContent />', () => {
describe('with triggerRef provided', () => {
const triggerKls = 'el-popper__trigger'
let wrapper: ReturnType<typeof mountContent>
beforeEach(() => {
const trigger = document.createElement('div')
trigger.className = triggerKls
popperInjection.triggerRef.value = trigger
})
afterEach(() => {
popperInjection.triggerRef.value = null
wrapper?.unmount()
})
it('should mount the component correctly and set popperInstance correctly', async () => {
wrapper = mountContent()
await nextTick()
expect(popperInjection.triggerRef).toBeDefined()
expect(wrapper.html()).toContain(AXIOM)
expect(popperInjection.popperInstanceRef.value).toBeDefined()
expect(wrapper.classes()).toEqual(['el-popper', 'is-dark'])
expect(wrapper.vm.contentStyle[0]).toHaveProperty('zIndex')
expect(wrapper.vm.contentStyle[1]).toBeUndefined()
})
it('should be able to be pure and themed', async () => {
wrapper = mountContent()
await nextTick()
await wrapper.setProps({
pure: true,
effect: 'custom',
})
expect(wrapper.classes()).toEqual(['el-popper', 'is-pure', 'is-custom'])
})
it('should be able to set customized styles', async () => {
wrapper = mountContent()
await nextTick()
const style = {
position: 'absolute',
}
await wrapper.setProps({
popperStyle: style,
})
expect(wrapper.vm.contentStyle[1]).toEqual(style)
})
it('should be able to emit events', async () => {
wrapper = mountContent()
await nextTick()
expect(wrapper.emitted()).not.toHaveProperty('mouseenter')
expect(wrapper.emitted()).not.toHaveProperty('mouseleave')
await wrapper.trigger('mouseenter')
expect(wrapper.emitted()).toHaveProperty('mouseenter')
await wrapper.trigger('mouseleave')
expect(wrapper.emitted()).toHaveProperty('mouseleave')
})
describe('instantiate popper instance', () => {
it('should be able to update the current instance', async () => {
wrapper = mountContent()
await nextTick()
jest
.spyOn(popperInjection.triggerRef.value, 'getBoundingClientRect')
.mockImplementation(() => ({
bottom: 1,
height: 0,
left: 0,
right: 0,
top: 0,
width: 0,
}))
wrapper.vm.$forceUpdate()
})
it('should be able to update the reference node', async () => {
wrapper = mountContent()
await nextTick()
const oldInstance = wrapper.vm.popperInstanceRef
const newRef = document.createElement('div')
newRef.classList.add('new-ref')
popperInjection.triggerRef.value = newRef
await nextTick()
expect(wrapper.vm.popperInstanceRef).not.toStrictEqual(oldInstance)
popperInjection.triggerRef.value = null
await nextTick()
expect(wrapper.vm.popperInstanceRef).toBe(null)
})
})
})
})