36 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
| import { mount } from '@vue/test-utils'
 | |
| import { asyncExpect } from '@/tests/utils'
 | |
| import Popover from '..'
 | |
| 
 | |
| describe('Popover', () => {
 | |
|   it('should show overlay when trigger is clicked', async () => {
 | |
|     const popover = mount({
 | |
|       render () {
 | |
|         return (
 | |
|           <Popover ref='popover' content="console.log('hello world')" title='code' trigger='click'>
 | |
|             <span>show me your code</span>
 | |
|           </Popover>
 | |
|         )
 | |
|       },
 | |
|     }, { sync: false })
 | |
|     await asyncExpect(() => {
 | |
|       expect(popover.vm.$refs.popover.getPopupDomNode()).toBe(null)
 | |
| 
 | |
|       popover.find('span').trigger('click')
 | |
|     }, 0)
 | |
|     let popup = null
 | |
|     await asyncExpect(() => {
 | |
|       popup = popover.vm.$refs.popover.getPopupDomNode()
 | |
|       expect(popup).not.toBe(null)
 | |
|       expect(popup.className).toContain('ant-popover-placement-top')
 | |
|     }, 1000)
 | |
|     await asyncExpect(() => {
 | |
|       expect(popup.innerHTML).toMatchSnapshot()
 | |
|       expect(popup.innerHTML).toMatchSnapshot()
 | |
|     })
 | |
|     await asyncExpect(() => {
 | |
| 
 | |
|     })
 | |
|   })
 | |
| })
 |