import userEvent from '@testing-library/user-event'; import React from 'react'; import { IntlProvider } from 'react-intl'; import { Provider } from 'react-redux'; import { __stub } from 'soapbox/api'; import { normalizePoll } from 'soapbox/normalizers/poll'; import { mockStore, render, screen, rootState } from '../../../jest/test-helpers'; import PollFooter from '../poll-footer'; let poll = normalizePoll({ id: 1, options: [{ title: 'Apples', votes_count: 0 }], emojis: [], expired: false, expires_at: '2020-03-24T19:33:06.000Z', multiple: true, voters_count: 0, votes_count: 0, own_votes: null, voted: false, }); 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: {} }, ]); }); 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(() => { poll = normalizePoll({ ...poll.toJS(), expired: false, }); }); 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(() => { poll = normalizePoll({ ...poll.toJS(), expired: true, }); }); 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(() => { poll = normalizePoll({ ...poll.toJS(), multiple: true, }); }); 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(() => { poll = normalizePoll({ ...poll.toJS(), multiple: false, }); }); it('does not render the Vote button', () => { render(<PollFooter poll={poll} showResults={false} selected={{}} />); expect(screen.queryAllByTestId('button')).toHaveLength(0); }); }); }); });