bigbuffet-rw/app/soapbox/components/polls/__tests__/poll-footer.test.tsx

140 lines
3.6 KiB
TypeScript
Raw Normal View History

import userEvent from '@testing-library/user-event';
2022-06-16 06:20:33 -07:00
import React from 'react';
import { IntlProvider } from 'react-intl';
import { Provider } from 'react-redux';
2022-06-16 06:20:33 -07:00
import { __stub } from 'soapbox/api';
2023-05-03 10:52:36 -07:00
import { mockStore, render, screen, rootState } from 'soapbox/jest/test-helpers';
import { type Poll } from 'soapbox/schemas';
2022-06-16 06:20:33 -07:00
import PollFooter from '../poll-footer';
2023-05-03 10:52:36 -07:00
let poll: Poll = {
id: '1',
options: [{
title: 'Apples',
votes_count: 0,
title_emojified: 'Apples',
}, {
title: 'Oranges',
votes_count: 0,
title_emojified: 'Oranges',
}],
2022-06-16 06:20:33 -07:00
emojis: [],
expired: false,
expires_at: '2020-03-24T19:33:06.000Z',
multiple: true,
voters_count: 0,
votes_count: 0,
own_votes: null,
voted: false,
2023-05-03 10:52:36 -07:00
};
2022-06-16 06:20:33 -07:00
describe('<PollFooter />', () => {
describe('with "showResults" enabled', () => {
it('renders the Refresh button', () => {
render(<PollFooter poll={poll} showResults selected={{}} />);
expect(screen.getByTestId('poll-footer')).toHaveTextContent('Refresh');
});
it('responds to the Refresh button', async() => {
__stub((mock) => {
mock.onGet('/api/v1/polls/1').reply(200, {});
});
const user = userEvent.setup();
const store = mockStore(rootState);
render(
<Provider store={store}>
<IntlProvider locale='en'>
<PollFooter poll={poll} showResults selected={{}} />
</IntlProvider>
</Provider>,
);
await user.click(screen.getByTestId('poll-refresh'));
const actions = store.getActions();
expect(actions).toEqual([
{ type: 'POLL_FETCH_REQUEST' },
{ type: 'POLLS_IMPORT', polls: [{}] },
{ type: 'POLL_FETCH_SUCCESS', poll: {} },
]);
});
2022-06-16 06:20:33 -07:00
it('does not render the Vote button', () => {
render(<PollFooter poll={poll} showResults selected={{}} />);
expect(screen.queryAllByTestId('button')).toHaveLength(0);
});
describe('when the Poll has not expired', () => {
beforeEach(() => {
2023-05-03 10:52:36 -07:00
poll = {
...poll,
2022-06-16 06:20:33 -07:00
expired: false,
2023-05-03 10:52:36 -07:00
};
2022-06-16 06:20:33 -07:00
});
it('renders time remaining', () => {
render(<PollFooter poll={poll} showResults selected={{}} />);
expect(screen.getByTestId('poll-expiration')).toHaveTextContent('Moments remaining');
});
});
describe('when the Poll has expired', () => {
beforeEach(() => {
2023-05-03 10:52:36 -07:00
poll = {
...poll,
2022-06-16 06:20:33 -07:00
expired: true,
2023-05-03 10:52:36 -07:00
};
2022-06-16 06:20:33 -07:00
});
it('renders closed', () => {
render(<PollFooter poll={poll} showResults selected={{}} />);
expect(screen.getByTestId('poll-expiration')).toHaveTextContent('Closed');
});
});
});
describe('with "showResults" disabled', () => {
it('does not render the Refresh button', () => {
render(<PollFooter poll={poll} showResults={false} selected={{}} />);
expect(screen.getByTestId('poll-footer')).not.toHaveTextContent('Refresh');
});
describe('when the Poll is multiple', () => {
beforeEach(() => {
2023-05-03 10:52:36 -07:00
poll = {
...poll,
2022-06-16 06:20:33 -07:00
multiple: true,
2023-05-03 10:52:36 -07:00
};
2022-06-16 06:20:33 -07:00
});
it('renders the Vote button', () => {
render(<PollFooter poll={poll} showResults={false} selected={{}} />);
expect(screen.getByTestId('button')).toHaveTextContent('Vote');
});
});
describe('when the Poll is not multiple', () => {
beforeEach(() => {
2023-05-03 10:52:36 -07:00
poll = {
...poll,
2022-06-16 06:20:33 -07:00
multiple: false,
2023-05-03 10:52:36 -07:00
};
2022-06-16 06:20:33 -07:00
});
it('does not render the Vote button', () => {
render(<PollFooter poll={poll} showResults={false} selected={{}} />);
expect(screen.queryAllByTestId('button')).toHaveLength(0);
});
});
});
});