Add tests for TrendsPanel

This commit is contained in:
Justin 2022-04-07 11:55:15 -04:00
parent 2929fc902f
commit ad381d7fbc
2 changed files with 73 additions and 1 deletions

View file

@ -16,7 +16,7 @@ const Hashtag = ({ hashtag }) => {
const brandColor = useSelector((state) => getSoapboxConfig(state).get('brandColor')); const brandColor = useSelector((state) => getSoapboxConfig(state).get('brandColor'));
return ( return (
<HStack alignItems='center' justifyContent='between'> <HStack alignItems='center' justifyContent='between' data-testid='hashtag'>
<Stack> <Stack>
<Permalink href={hashtag.get('url')} to={`/tags/${hashtag.get('name')}`} className='hover:underline'> <Permalink href={hashtag.get('url')} to={`/tags/${hashtag.get('name')}`} className='hover:underline'>
<Text tag='span' size='sm' weight='semibold'>#{hashtag.get('name')}</Text> <Text tag='span' size='sm' weight='semibold'>#{hashtag.get('name')}</Text>

View file

@ -0,0 +1,72 @@
import { Map as ImmutableMap, fromJS } from 'immutable';
import React from 'react';
import { render, screen } from '../../../../jest/test-helpers';
import TrendsPanel from '../trends-panel';
describe('<TrendsPanel />', () => {
it('renders trending hashtags', () => {
const store = {
trends: ImmutableMap({
items: fromJS([{
name: 'hashtag 1',
history: [{ accounts: [] }],
}]),
}),
};
render(<TrendsPanel limit={1} />, null, store);
expect(screen.getByTestId('hashtag')).toHaveTextContent(/hashtag 1/i);
});
it('renders multiple trends', () => {
const store = {
trends: ImmutableMap({
items: fromJS([
{
name: 'hashtag 1',
history: [{ accounts: [] }],
},
{
name: 'hashtag 2',
history: [{ accounts: [] }],
},
]),
}),
};
render(<TrendsPanel limit={3} />, null, store);
expect(screen.queryAllByTestId('hashtag')).toHaveLength(2);
});
it('respects the limit prop', () => {
const store = {
trends: ImmutableMap({
items: fromJS([
{
name: 'hashtag 1',
history: [{ accounts: [] }],
},
{
name: 'hashtag 2',
history: [{ accounts: [] }],
},
]),
}),
};
render(<TrendsPanel limit={1} />, null, store);
expect(screen.queryAllByTestId('hashtag')).toHaveLength(1);
});
it('renders empty', () => {
const store = {
trends: ImmutableMap({
items: fromJS([]),
}),
};
render(<TrendsPanel limit={1} />, null, store);
expect(screen.queryAllByTestId('hashtag')).toHaveLength(0);
});
});