Skip to content

Commit

Permalink
fixup! Fix(web-react): FileUploaderInput className #DS-1508
Browse files Browse the repository at this point in the history
  • Loading branch information
curdaj committed Oct 22, 2024
1 parent 7eea633 commit 9836b8d
Showing 1 changed file with 7 additions and 80 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { render, screen, act, fireEvent, waitFor } from '@testing-library/react';
import { render, screen } from '@testing-library/react';
import React from 'react';
import ReactDOMServer from 'react-dom/server';
import { classNamePrefixProviderTest } from '../../../../tests/providerTests/classNamePrefixProviderTest';
Expand All @@ -14,94 +14,21 @@ describe('FileUploaderInput', () => {

validationTextPropsTest(FileUploaderInput, '.FileUploaderInput__validationText');

it('should have drag-and-drop listeners in CSR when draggable is supported', () => {
it('should have drag-and-drop class in Client component', () => {
render(<FileUploaderInput id="test-uploader" name="test-uploader" label="upload" data-testid="test" />);

const dropZone = screen.getAllByTestId('test')[0];

expect(dropZone).toHaveClass('has-drag-and-drop');
});

it('should not have drag-and-drop listeners in SSR', () => {
const ui = <FileUploaderInput id="test-uploader" name="test-uploader" label="upload" data-testid="test" />;
it('should not have drag-and-drop class in Server component', () => {
const container = document.createElement('div');
document.body.appendChild(container);
container.innerHTML = ReactDOMServer.renderToString(ui);
container.innerHTML = ReactDOMServer.renderToString(
<FileUploaderInput id="test-uploader" name="test-uploader" label="upload" data-testid="test" />,
);

act(() => {
render(ui, { hydrate: true, container });
});

const dropZone = screen.getAllByTestId('test')[0];

expect(dropZone).not.toHaveClass('has-drag-and-drop');
});
});

describe('Listener approach', () => {
it('should not register onDragOver event listener during SSR', () => {
// Simulace addEventListener pomocí jest.spyOn
const addEventListenerSpy = jest.spyOn(document, 'addEventListener');

// Simulujeme SSR renderováním pouze komponenty bez vykonání useEffect
// Abychom simulovali SSR, renderování komponenty nebude obsahovat "hydration" logiku.
render(<FileUploaderInput name="bagr" id="pokus" data-testid="test" />, { hydrate: false });

// Ověřujeme, že event listener nebyl zaregistrován
expect(addEventListenerSpy).not.toHaveBeenCalledWith('dragover', expect.any(Function));

// Vyčistíme spy
addEventListenerSpy.mockRestore();
});

it('should register onDragOver event listener during CSR', () => {
const addEventListenerSpy = jest.spyOn(document, 'addEventListener');

// Simulujeme CSR renderováním komponenty s vykonáním useEffect
render(<FileUploaderInput name="bagr" id="pokus" data-testid="test" />, { hydrate: true });

expect(addEventListenerSpy).toHaveBeenCalledWith('dragover', expect.any(Function));

addEventListenerSpy.mockRestore();
});
});

describe('mock useEffect approach', () => {
it('should not register onDragOver event listener during SSR', () => {
jest.spyOn(React, 'useEffect').mockImplementation(() => {});
const addEventListenerSpy = jest.spyOn(window, 'addEventListener');

// Simulujeme SSR renderování komponenty
render(<FileUploaderInput name="bagr" id="pokus" data-testid="test" />);

// Kontrolujeme, že během SSR nebyl zaregistrován žádný onDragOver listener
expect(addEventListenerSpy).not.toHaveBeenCalledWith('dragover', expect.any(Function));

addEventListenerSpy.mockRestore();
});

it('should register onDragOver event listener during CSR', () => {
const addEventListenerSpy = jest.spyOn(window, 'addEventListener');

// Simulujeme CSR renderování komponenty
render(<FileUploaderInput name="bagr" id="pokus" data-testid="test" />);

// Kontrolujeme, že během CSR byl zaregistrován onDragOver listener
expect(addEventListenerSpy).toHaveBeenCalledWith('dragover', expect.any(Function));

addEventListenerSpy.mockRestore();
});
});

describe('is-dragging class onDragOver event', () => {
it('should have is-dragging class on dragOver', () => {
render(<FileUploaderInput name="bagr" id="pokus" data-testid="test" />);
const dropZone = screen.getAllByTestId('test')[0];

fireEvent.dragOver(dropZone);

waitFor(() => {
expect(dropZone).toHaveClass('is-dragging');
});
expect(container).not.toContainHTML('has-drag-and-drop');
});
});

0 comments on commit 9836b8d

Please sign in to comment.