12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- import React from 'react';
- import { mount } from 'enzyme';
- export default function focusTest(Component) {
- describe('focus and blur', () => {
- beforeAll(() => {
- jest.useFakeTimers();
- });
- let container;
- beforeEach(() => {
- container = document.createElement('div');
- document.body.appendChild(container);
- });
- afterAll(() => {
- jest.useRealTimers();
- });
- afterEach(() => {
- document.body.removeChild(container);
- });
- it('focus() and onFocus', () => {
- const handleFocus = jest.fn();
- const wrapper = mount(<Component onFocus={handleFocus} />, { attachTo: container });
- wrapper.instance().focus();
- jest.runAllTimers();
- expect(handleFocus).toHaveBeenCalled();
- });
- it('blur() and onBlur', () => {
- const handleBlur = jest.fn();
- const wrapper = mount(<Component onBlur={handleBlur} />, { attachTo: container });
- wrapper.instance().focus();
- jest.runAllTimers();
- wrapper.instance().blur();
- jest.runAllTimers();
- expect(handleBlur).toHaveBeenCalled();
- });
- it('autoFocus', () => {
- const handleFocus = jest.fn();
- mount(<Component autoFocus onFocus={handleFocus} />, { attachTo: container });
- jest.runAllTimers();
- expect(handleFocus).toHaveBeenCalled();
- });
- });
- }
|