Fix tests
This commit is contained in:
parent
6bae81a758
commit
15594df644
2 changed files with 29 additions and 25 deletions
|
@ -1,5 +1,6 @@
|
||||||
import userEvent from '@testing-library/user-event';
|
import userEvent from '@testing-library/user-event';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import { VirtuosoMockContext } from 'react-virtuoso';
|
||||||
|
|
||||||
import { __stub } from 'soapbox/api';
|
import { __stub } from 'soapbox/api';
|
||||||
import { ChatProvider } from 'soapbox/contexts/chat-context';
|
import { ChatProvider } from 'soapbox/contexts/chat-context';
|
||||||
|
@ -8,29 +9,16 @@ import { render, screen, waitFor } from '../../../../../jest/test-helpers';
|
||||||
import ChatSearch from '../chat-search';
|
import ChatSearch from '../chat-search';
|
||||||
|
|
||||||
const renderComponent = () => render(
|
const renderComponent = () => render(
|
||||||
|
<VirtuosoMockContext.Provider value={{ viewportHeight: 300, itemHeight: 100 }}>
|
||||||
<ChatProvider>
|
<ChatProvider>
|
||||||
<ChatSearch />
|
<ChatSearch />
|
||||||
</ChatProvider>,
|
</ChatProvider>,
|
||||||
|
</VirtuosoMockContext.Provider>,
|
||||||
);
|
);
|
||||||
|
|
||||||
describe('<ChatSearch />', () => {
|
describe('<ChatSearch />', () => {
|
||||||
it('renders correctly', () => {
|
|
||||||
renderComponent();
|
|
||||||
|
|
||||||
expect(screen.getByTestId('pane-header')).toHaveTextContent('Messages');
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when the pane is closed', () => {
|
|
||||||
it('does not render the search input', () => {
|
|
||||||
renderComponent();
|
|
||||||
expect(screen.queryAllByTestId('search')).toHaveLength(0);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when the pane is open', () => {
|
|
||||||
beforeEach(async() => {
|
beforeEach(async() => {
|
||||||
renderComponent();
|
renderComponent();
|
||||||
await userEvent.click(screen.getByTestId('icon-button'));
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('renders the search input', () => {
|
it('renders the search input', () => {
|
||||||
|
@ -38,6 +26,7 @@ describe('<ChatSearch />', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('when searching', () => {
|
describe('when searching', () => {
|
||||||
|
describe('with results', () => {
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
__stub((mock) => {
|
__stub((mock) => {
|
||||||
mock.onGet('/api/v1/accounts/search').reply(200, [{
|
mock.onGet('/api/v1/accounts/search').reply(200, [{
|
||||||
|
@ -51,8 +40,6 @@ describe('<ChatSearch />', () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
it('renders accounts', async() => {
|
it('renders accounts', async() => {
|
||||||
renderComponent();
|
|
||||||
|
|
||||||
const user = userEvent.setup();
|
const user = userEvent.setup();
|
||||||
await user.type(screen.getByTestId('search'), 'ste');
|
await user.type(screen.getByTestId('search'), 'ste');
|
||||||
|
|
||||||
|
@ -61,5 +48,22 @@ describe('<ChatSearch />', () => {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('without results', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
__stub((mock) => {
|
||||||
|
mock.onGet('/api/v1/accounts/search').reply(200, []);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('renders accounts', async() => {
|
||||||
|
const user = userEvent.setup();
|
||||||
|
await user.type(screen.getByTestId('search'), 'ste');
|
||||||
|
|
||||||
|
await waitFor(() => {
|
||||||
|
expect(screen.getByTestId('no-results')).toBeInTheDocument();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -13,7 +13,7 @@ const EmptyResultsBlankslate = () => {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Stack justifyContent='center' alignItems='center' space={2} className='h-full w-2/3 mx-auto'>
|
<Stack justifyContent='center' alignItems='center' space={2} className='h-full w-2/3 mx-auto'>
|
||||||
<Text weight='bold' size='lg' align='center'>
|
<Text weight='bold' size='lg' align='center' data-testid='no-results'>
|
||||||
{intl.formatMessage(messages.title)}
|
{intl.formatMessage(messages.title)}
|
||||||
</Text>
|
</Text>
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue