From ad381d7fbc1a939dcddfcba7c01752d795c491a1 Mon Sep 17 00:00:00 2001 From: Justin Date: Thu, 7 Apr 2022 11:55:15 -0400 Subject: [PATCH] Add tests for TrendsPanel --- app/soapbox/components/hashtag.js | 2 +- .../__tests__/trends-panel.test.tsx | 72 +++++++++++++++++++ 2 files changed, 73 insertions(+), 1 deletion(-) create mode 100644 app/soapbox/features/ui/components/__tests__/trends-panel.test.tsx diff --git a/app/soapbox/components/hashtag.js b/app/soapbox/components/hashtag.js index d74911f2e..1b19bbff3 100644 --- a/app/soapbox/components/hashtag.js +++ b/app/soapbox/components/hashtag.js @@ -16,7 +16,7 @@ const Hashtag = ({ hashtag }) => { const brandColor = useSelector((state) => getSoapboxConfig(state).get('brandColor')); return ( - + #{hashtag.get('name')} diff --git a/app/soapbox/features/ui/components/__tests__/trends-panel.test.tsx b/app/soapbox/features/ui/components/__tests__/trends-panel.test.tsx new file mode 100644 index 000000000..f2d310c55 --- /dev/null +++ b/app/soapbox/features/ui/components/__tests__/trends-panel.test.tsx @@ -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('', () => { + it('renders trending hashtags', () => { + const store = { + trends: ImmutableMap({ + items: fromJS([{ + name: 'hashtag 1', + history: [{ accounts: [] }], + }]), + }), + }; + + render(, 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(, 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(, null, store); + expect(screen.queryAllByTestId('hashtag')).toHaveLength(1); + }); + + it('renders empty', () => { + const store = { + trends: ImmutableMap({ + items: fromJS([]), + }), + }; + + render(, null, store); + expect(screen.queryAllByTestId('hashtag')).toHaveLength(0); + }); +});