76 lines
No EOL
1.9 KiB
TypeScript
76 lines
No EOL
1.9 KiB
TypeScript
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
|
|
import { render, screen } from '../../../../jest/test-helpers';
|
|
import ChatMessageReaction from '../chat-message-reaction';
|
|
|
|
const emojiReaction = ({
|
|
name: '👍',
|
|
count: 1,
|
|
me: false,
|
|
});
|
|
|
|
describe('<ChatMessageReaction />', () => {
|
|
it('renders properly', () => {
|
|
render(
|
|
<ChatMessageReaction
|
|
emojiReaction={emojiReaction}
|
|
onAddReaction={jest.fn()}
|
|
onRemoveReaction={jest.fn()}
|
|
/>,
|
|
);
|
|
|
|
expect(screen.getByRole('img').getAttribute('alt')).toEqual(emojiReaction.name);
|
|
expect(screen.getByRole('button')).toHaveTextContent(String(emojiReaction.count));
|
|
});
|
|
|
|
it('triggers the "onAddReaction" function', async () => {
|
|
const onAddFn = jest.fn();
|
|
const onRemoveFn = jest.fn();
|
|
const user = userEvent.setup();
|
|
|
|
render(
|
|
<ChatMessageReaction
|
|
emojiReaction={emojiReaction}
|
|
onAddReaction={onAddFn}
|
|
onRemoveReaction={onRemoveFn}
|
|
/>,
|
|
);
|
|
|
|
expect(onAddFn).not.toBeCalled();
|
|
expect(onRemoveFn).not.toBeCalled();
|
|
|
|
await user.click(screen.getByRole('button'));
|
|
|
|
// add function triggered
|
|
expect(onAddFn).toBeCalled();
|
|
expect(onRemoveFn).not.toBeCalled();
|
|
});
|
|
|
|
it('triggers the "onRemoveReaction" function', async () => {
|
|
const onAddFn = jest.fn();
|
|
const onRemoveFn = jest.fn();
|
|
const user = userEvent.setup();
|
|
|
|
render(
|
|
<ChatMessageReaction
|
|
emojiReaction={({
|
|
name: '👍',
|
|
count: 1,
|
|
me: true,
|
|
})}
|
|
onAddReaction={onAddFn}
|
|
onRemoveReaction={onRemoveFn}
|
|
/>,
|
|
);
|
|
|
|
expect(onAddFn).not.toBeCalled();
|
|
expect(onRemoveFn).not.toBeCalled();
|
|
|
|
await user.click(screen.getByRole('button'));
|
|
|
|
// remove function triggered
|
|
expect(onAddFn).not.toBeCalled();
|
|
expect(onRemoveFn).toBeCalled();
|
|
});
|
|
}); |