56 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
| import { mount } from '@vue/test-utils'
 | |
| import { asyncExpect } from '../utils'
 | |
| 
 | |
| export default function focusTest (Component) {
 | |
|   describe('focus and blur', () => {
 | |
|     beforeAll(() => {
 | |
|       jest.useFakeTimers()
 | |
|     })
 | |
| 
 | |
|     afterAll(() => {
 | |
|       jest.useRealTimers()
 | |
|     })
 | |
| 
 | |
|     it('focus() and onFocus', () => {
 | |
|       const handleFocus = jest.fn()
 | |
|       const wrapper = mount({
 | |
|         render (h) {
 | |
|           return <Component ref='component' onFocus={handleFocus} />
 | |
|         },
 | |
|       }, { attachToDocument: true, sync: false })
 | |
|       wrapper.vm.$refs.component.focus()
 | |
|       jest.runAllTimers()
 | |
|       expect(handleFocus).toBeCalled()
 | |
|     })
 | |
| 
 | |
|     it('blur() and onBlur', async () => {
 | |
|       const handleBlur = jest.fn()
 | |
|       const wrapper = mount({
 | |
|         render (h) {
 | |
|           return <Component ref='component' onBlur={handleBlur} />
 | |
|         },
 | |
|       }, { attachToDocument: true, sync: false })
 | |
|       wrapper.vm.$refs.component.focus()
 | |
|       wrapper.vm.$refs.component.blur()
 | |
|       jest.runAllTimers()
 | |
|       await asyncExpect(() => {
 | |
|         expect(handleBlur).toBeCalled()
 | |
|       })
 | |
|     })
 | |
| 
 | |
|     it('autoFocus', (done) => {
 | |
|       jest.useRealTimers()
 | |
|       const handleFocus = jest.fn()
 | |
|       mount({
 | |
|         render (h) {
 | |
|           return <Component autoFocus onFocus={handleFocus} />
 | |
|         },
 | |
|       }, { attachToDocument: true, sync: false })
 | |
|       setTimeout(() => {
 | |
|         expect(handleFocus).toBeCalled()
 | |
|         done()
 | |
|       }, 1000)
 | |
|     })
 | |
|   })
 | |
| }
 |