import userEvent from '@testing-library/user-event'; import React from 'react'; import { normalizeEmojiReaction } from 'soapbox/normalizers/emoji-reaction'; import { render, screen } from '../../../../jest/test-helpers'; import ChatMessageReaction from '../chat-message-reaction'; const emojiReaction = normalizeEmojiReaction({ name: '👍', count: 1, me: false, }); describe('', () => { it('renders properly', () => { render( , ); 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( , ); 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( , ); expect(onAddFn).not.toBeCalled(); expect(onRemoveFn).not.toBeCalled(); await user.click(screen.getByRole('button')); // remove function triggered expect(onAddFn).not.toBeCalled(); expect(onRemoveFn).toBeCalled(); }); });