Тестирование файла Drag and Drop в реакции JS с использованием шутливого фермента - PullRequest
0 голосов
/ 16 марта 2020

Я пытался разработать компонент для перетаскивания файлов с использованием реакции, но у меня возникли проблемы при написании тестового примера для него. Я просмотрел несколько сайтов в Интернете, но не смог добиться какого-либо прогресса

Вот компонент перетаскивания, написанный мной: он в основном прослушивает 4 события и вызывает соответствующие функции

const DragAndDropFile: React.FC<IProps> = ({ handleFileDrop, content, fileType }) => {
  const [dragging, setDragging] = useState(false);
  const [supportedFileTypeError, setSupportedFileTypeError] = useState(false);
  const [t] = useTranslation();
  let dragCounter: number;
  console.log('ll');
  // preventDefault  prevents the default behavior of the browser when something is dragged in or dropped (e.g. open the file )
  // stopPropagation stops the event from being propagated through parent and child elements
  const handleDrag = (e: DragEvent) => {
    console.log('heref');
    e.preventDefault();
    e.stopPropagation();
  };
  const handleDragIn = (e: DragEvent) => {
    e.preventDefault();
    e.stopPropagation();
    dragCounter++;
    setSupportedFileTypeError(false);
    if (e.dataTransfer && e.dataTransfer.items && e.dataTransfer.items.length > 0) {
      setDragging(true);
    }
  };
  const handleDragOut = (e: DragEvent) => {
    e.preventDefault();
    e.stopPropagation();
    dragCounter--;
    if (dragCounter > 0) {
      return;
    }
    setDragging(false);
  };
  const handleDrop = (e: DragEvent) => {
    e.preventDefault();
    e.stopPropagation();
    setDragging(false);
    if (e.dataTransfer && e.dataTransfer.files && e.dataTransfer.files.length > 0) {
      if (fileType.includes(e.dataTransfer.files[0].type)) {
        handleFileDrop(e.dataTransfer.files[0]);
        e.dataTransfer.clearData();
      } else {
        setSupportedFileTypeError(true);
      }
    }
  };

  useEffect(() => {
    const div = dropRef.current;
    dragCounter = 0;
    if (div) {
      div.addEventListener('dragenter', handleDragIn);
      div.addEventListener('dragleave', handleDragOut);
      div.addEventListener('dragover', handleDrag);
      div.addEventListener('drop', handleDrop, false);
    }

    return () => {
      if (div) {
        div.removeEventListener('dragenter', handleDragIn);
        div.removeEventListener('dragleave', handleDragOut);
        div.removeEventListener('dragover', handleDrag);
        div.removeEventListener('drop', handleDrop);
      }
    };
  }, []);

  return (
    <div className="drag-and-drop-div-main" ref={dropRef}>
      {dragging && (
        <FlexLayout
          className="drag-and-drop-true"
          flexDirection={EFlexDirection.COLUMN}
          justifyContent={EFlexJustifyContent.SPACE_EVENLY}
        >
          <Icon
            title={EIconTitle.DOWNLOAD}
            width="26px"
            height="26px"
            stroke="#1e88e5" /* stroke: $brand-blue-2 */
          />
          {t('common.dropFileText')}
        </FlexLayout>
      )}
      {supportedFileTypeError && (
        <div className="drag-and-drop-error">Supported file types - {fileType.join()}</div>
      )}
      {content}
    </div>
  );
};

Я пытался написать для него несколько юнит-тестов -

describe('Drag and drop test', () => {
  const handleFileDropFunction = jest.fn();
  const handleDrag = jest.fn();
  const fileTypeParameter = ['text/xml'];

  it('should call handleDrag function when dragging starts', async done => {
    const wrapper = renderWithProviders(
      <DragAndDropFile handleFileDrop={handleFileDropFunction} fileType={fileTypeParameter} />
    );
    const mouseDrag = new Event('dragover');
    const mouseDragIn = new Event('dragenter');
    const mouseDragleave = new Event('dragover');
    const top = window.document.documentElement;
    top.dispatchEvent(mouseDrag);
    top.dispatchEvent(mouseDragIn);
    top.dispatchEvent(mouseDragleave);
    console.log(wrapper.find('.drag-and-drop-div-main').props());
    expect(handleDrag).toHaveBeenCalled();
  });
});

Но функция обработчика никогда не вызывается. Какую ошибку я делаю? Как мне подойти? Буду признателен за любую помощь в этом отношении

...