Skip to content

Commit

Permalink
fix: reflect separateGiphyPreview prop value in VirtualizedMessageList (
Browse files Browse the repository at this point in the history
  • Loading branch information
MartinCupela authored May 28, 2024
1 parent 5a68c09 commit 5d00b56
Show file tree
Hide file tree
Showing 2 changed files with 97 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,10 @@ export const useGiphyPreview = <

if (separateGiphyPreview) client.on('message.new', handleEvent);
return () => client.off('message.new', handleEvent);
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [separateGiphyPreview]);
}, [client, separateGiphyPreview]);

return { giphyPreviewMessage, setGiphyPreviewMessage };
return {
giphyPreviewMessage,
setGiphyPreviewMessage: separateGiphyPreview ? setGiphyPreviewMessage : undefined,
};
};
92 changes: 92 additions & 0 deletions src/components/MessageList/hooks/__tests__/useGiphyPreview.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
import React from 'react';
import { act } from '@testing-library/react';
import { renderHook } from '@testing-library/react-hooks';
import {
dispatchMessageNewEvent,
generateMessage,
generateUser,
getTestClientWithUser,
} from '../../../../mock-builders';

import { useGiphyPreview } from '../VirtualizedMessageList';
import { ChatProvider } from '../../../../context';

const me = generateUser();
const otherUser = generateUser();

const ownGiphyMessage = generateMessage({ command: 'giphy', user: me });
const foreignGiphyMessage = generateMessage({ command: 'giphy', user: otherUser });
const ownNonGiphyMessage = generateMessage({ user: me });
const foreignNonGiphyMessage = generateMessage({ user: otherUser });

const render = ({ client, separateGiphyPreview }) => {
const wrapper = ({ children }) => <ChatProvider value={{ client }}>{children}</ChatProvider>;
return renderHook(() => useGiphyPreview(separateGiphyPreview), { wrapper });
};
describe('useGiphyPreview', () => {
it('does not expose setGiphyPreviewMessage function if separateGiphyPreview is disabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: false });
expect(result.current.giphyPreviewMessage).toBeUndefined();
expect(result.current.setGiphyPreviewMessage).toBeUndefined();
});

it('exposes setGiphyPreviewMessage function if separateGiphyPreview is enabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: true });
expect(result.current.giphyPreviewMessage).toBeUndefined();
expect(result.current.setGiphyPreviewMessage).toStrictEqual(expect.any(Function));
});

it('unsets giphy preview with new own giphy message when separateGiphyPreview is enabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: true });
await act(() => {
result.current.setGiphyPreviewMessage(ownGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
await act(() => {
dispatchMessageNewEvent(client, ownGiphyMessage);
});
expect(result.current.giphyPreviewMessage).toBeUndefined();
});

it('does not unset giphy preview with new foreign giphy message when separateGiphyPreview is enabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: true });
await act(() => {
result.current.setGiphyPreviewMessage(ownGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
await act(() => {
dispatchMessageNewEvent(client, foreignGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
});

it('does not unset giphy preview with new own non-giphy message when separateGiphyPreview is enabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: true });
await act(() => {
result.current.setGiphyPreviewMessage(ownGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
await act(() => {
dispatchMessageNewEvent(client, ownNonGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
});

it('does not unset giphy preview with new foreign non-giphy message when separateGiphyPreview is enabled', async () => {
const client = await getTestClientWithUser(me);
const { result } = render({ client, separateGiphyPreview: true });
await act(() => {
result.current.setGiphyPreviewMessage(ownGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
await act(() => {
dispatchMessageNewEvent(client, foreignNonGiphyMessage);
});
expect(result.current.giphyPreviewMessage.id).toBe(ownGiphyMessage.id);
});
});

0 comments on commit 5d00b56

Please sign in to comment.