Fix tests

This commit is contained in:
Chewbacca 2022-12-08 15:09:58 -05:00 committed by Alex Gleason
parent 6bae81a758
commit 15594df644
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 29 additions and 25 deletions

View file

@ -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();
});
});
});
}); });
}); });

View file

@ -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>