/* eslint-disable react/no-string-refs, react/prefer-es6-class */ import React from 'react'; import { act } from 'react-dom/test-utils'; import Upload from '..'; import { setup, teardown } from './mock'; import mountTest from '../../../tests/shared/mountTest'; import { fireEvent, render, waitFor } from '../../../tests/utils'; describe('Upload.Dragger', () => { mountTest(Upload.Dragger); beforeEach(() => setup()); afterEach(() => teardown()); it('support drag file with over style', async () => { jest.useFakeTimers(); const { container: wrapper } = render(
, ); fireEvent.dragOver(wrapper.querySelector('.ant-upload-drag-container'), { target: { files: [{ file: 'foo.png' }], }, }); await act(() => { jest.runAllTimers(); }); await waitFor(() => { expect(wrapper.querySelector('.ant-upload-drag')).toHaveClass('ant-upload-drag-hover'); }); jest.useRealTimers(); }); it('support onDrop when files are dropped onto upload area', async () => { const onDrop = jest.fn(); const { container: wrapper } = render(
, ); fireEvent.drop(wrapper.querySelector('.ant-upload-drag-container'), { dataTransfer: { files: [new File(['foo'], 'foo.png', { type: 'image/png' })], }, }); await waitFor(() => { expect(onDrop).toHaveBeenCalled(); }); }); });