2022-11-25 09:04:11 -08:00
|
|
|
import React from 'react';
|
2022-04-16 17:03:33 -07:00
|
|
|
|
2022-07-11 15:25:07 -07:00
|
|
|
import { updateNotifications } from 'soapbox/actions/notifications';
|
|
|
|
import { render, screen, rootState, createTestStore } from 'soapbox/jest/test-helpers';
|
2022-04-16 17:03:33 -07:00
|
|
|
|
2022-07-11 15:25:07 -07:00
|
|
|
import Notification from '../notification';
|
2022-04-16 17:03:33 -07:00
|
|
|
|
|
|
|
/** Prepare the notification for use by the component */
|
|
|
|
const normalize = (notification: any) => {
|
|
|
|
const store = createTestStore(rootState);
|
|
|
|
store.dispatch(updateNotifications(notification) as any);
|
|
|
|
const state = store.getState();
|
|
|
|
|
|
|
|
return {
|
|
|
|
// @ts-ignore
|
2022-11-12 06:18:24 -08:00
|
|
|
notification: state.notifications.items.get(notification.id)!,
|
2022-04-16 17:03:33 -07:00
|
|
|
state,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('<Notification />', () => {
|
|
|
|
it('renders a follow notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-follow.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toBeInTheDocument();
|
|
|
|
expect(screen.getByTestId('account')).toContainHTML('neko@rdrama.cc');
|
2022-05-24 13:49:59 -07:00
|
|
|
expect(screen.getByTestId('message')).toHaveTextContent('Nekobit followed you');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('grouped notifications', () => {
|
|
|
|
it('renders a grouped follow notification for more than 2', async() => {
|
2022-07-06 10:24:45 -07:00
|
|
|
const { notification, state } = normalize({
|
|
|
|
...require('soapbox/__fixtures__/notification-follow.json'),
|
|
|
|
total_count: 5,
|
|
|
|
});
|
2022-05-24 13:49:59 -07:00
|
|
|
|
2022-07-06 10:24:45 -07:00
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
2022-05-24 13:49:59 -07:00
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toBeInTheDocument();
|
|
|
|
expect(screen.getByTestId('account')).toContainHTML('neko@rdrama.cc');
|
|
|
|
expect(screen.getByTestId('message')).toHaveTextContent('Nekobit + 4 others followed you');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a grouped follow notification for 1', async() => {
|
2022-07-06 10:24:45 -07:00
|
|
|
const { notification, state } = normalize({
|
|
|
|
...require('soapbox/__fixtures__/notification-follow.json'),
|
|
|
|
total_count: 2,
|
|
|
|
});
|
2022-05-24 13:49:59 -07:00
|
|
|
|
2022-07-06 10:24:45 -07:00
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
2022-05-24 13:49:59 -07:00
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toBeInTheDocument();
|
|
|
|
expect(screen.getByTestId('account')).toContainHTML('neko@rdrama.cc');
|
|
|
|
expect(screen.getByTestId('message')).toHaveTextContent('Nekobit + 1 other followed you');
|
|
|
|
});
|
2022-04-16 17:03:33 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a favourite notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-favourite.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('Hollahollara@spinster.xyz');
|
|
|
|
expect(screen.getByTestId('status')).toContainHTML('https://media.gleasonator.com');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a follow_request notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-follow_request.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toBeInTheDocument();
|
|
|
|
expect(screen.getByTestId('account')).toContainHTML('alex@spinster.xyz');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a mention notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-mention.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('silverpill@mitra.social');
|
|
|
|
expect(screen.getByTestId('status')).toContainHTML('ActivityPub spec');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a move notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-move.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('alex@fedibird.com');
|
|
|
|
expect(screen.getByTestId('account')).toContainHTML('benis911');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a pleroma:emoji_reaction notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-pleroma-emoji_reaction.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('😮');
|
|
|
|
expect(screen.getByTestId('status')).toContainHTML('Super Mario 64');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a pleroma:chat_mention notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-pleroma-chat_mention.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('dave');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a poll notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-poll.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toBeInTheDocument();
|
|
|
|
expect(screen.getByTestId('status')).toContainHTML('what do you guys think?');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders a reblog notification', async() => {
|
|
|
|
const { notification, state } = normalize(require('soapbox/__fixtures__/notification-reblog.json'));
|
|
|
|
|
|
|
|
render(<Notification notification={notification} />, undefined, state);
|
|
|
|
|
|
|
|
expect(screen.getByTestId('notification')).toContainHTML('rob@nicecrew.digital');
|
|
|
|
expect(screen.getByTestId('status')).toContainHTML('never downloaded TikTok');
|
|
|
|
});
|
|
|
|
});
|