From de2c205cfa1da296a2870b0e417f66f54551dfcd Mon Sep 17 00:00:00 2001 From: Ivan Danyliuk <80050483+IvanDanyliuk@users.noreply.github.com> Date: Wed, 13 Oct 2021 13:12:53 +0300 Subject: [PATCH] Create tests for ExpertInfo, ExpertProfileView, and AutoPaginationExpertsList (#613) --- .../AutoPaginationExpertsList.test.tsx | 228 ++++++++++++++++++ .../components/__test__/ExpertInfo.test.tsx | 63 +++++ .../__test__/ExpertProfileView.test.tsx | 48 ++++ 3 files changed, 339 insertions(+) create mode 100644 src/old/modules/experts/components/__test__/AutoPaginationExpertsList.test.tsx create mode 100644 src/old/modules/experts/components/__test__/ExpertInfo.test.tsx create mode 100644 src/old/modules/experts/components/__test__/ExpertProfileView.test.tsx diff --git a/src/old/modules/experts/components/__test__/AutoPaginationExpertsList.test.tsx b/src/old/modules/experts/components/__test__/AutoPaginationExpertsList.test.tsx new file mode 100644 index 000000000..61ec914fb --- /dev/null +++ b/src/old/modules/experts/components/__test__/AutoPaginationExpertsList.test.tsx @@ -0,0 +1,228 @@ +import React from 'react'; +import { screen, render } from '@testing-library/react'; +import { MemoryRouter } from 'react-router-dom'; +import { IExpert } from 'old/lib/types'; +import { AutoPaginationExpertsList } from '../AutoPaginationExpertsList'; + +const setPageFunc = jest.fn(); + +const EXPERTS_LIST: IExpert[] = [ + { + id: 10, + firstName: 'Марія', + lastName: 'Марієнко', + email: 'masha@mail.com', + qualification: 'Лікар вищої категорії', + phone: '+380956456969', + avatar: 'https://i.pravatar.cc/300?img=16', + bio: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit', + socialNetwork: 'https://www.youtube.com', + directions: [ + { + id: 6, + name: 'cardiology', + label: 'Кардіологія', + color: '#00ffff', + hasDoctors: true, + hasPosts: true, + }, + { + id: 4, + name: 'therapy', + label: 'Терапія', + color: '#ffee58', + hasDoctors: true, + hasPosts: true, + }, + ], + mainInstitution: { + id: 5, + city: { + id: 55, + name: 'Бровари', + }, + name: 'Medical Idea', + }, + lastAddedPost: { + id: 266, + title: 'Офтальмонологія', + }, + }, + { + id: 6, + firstName: 'Палана', + lastName: 'Литвинова', + email: 'PalanaLitvinova514@mail.com', + qualification: 'Кандидат медичних наук', + phone: '+380633484351', + avatar: 'https://i.pravatar.cc/300?img=44', + bio: + 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ', + socialNetwork: 'https://www.youtube.com', + directions: [ + { + id: 6, + name: 'cardiology', + label: 'Кардіологія', + color: '#00ffff', + hasDoctors: true, + hasPosts: true, + }, + { + id: 4, + name: 'therapy', + label: 'Терапія', + color: '#ffee58', + hasDoctors: true, + hasPosts: true, + }, + ], + mainInstitution: { + id: 4, + city: { + id: 119, + name: 'Дніпро', + }, + name: 'Медікум', + }, + lastAddedPost: { + id: 246, + title: 'Sit amet consectetur', + }, + }, + { + id: 6, + firstName: 'Таржеман', + lastName: 'Соколов', + email: 't.sokolov@mail.com', + qualification: 'Кандидат медичних наук', + phone: '+380633335533', + avatar: 'https://i.pravatar.cc/300?img=44', + bio: + 'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor ', + socialNetwork: 'https://www.youtube.com', + directions: [ + { + id: 4, + name: 'therapy', + label: 'Терапія', + color: '#ffee58', + hasDoctors: true, + hasPosts: true, + }, + ], + mainInstitution: { + id: 4, + city: { + id: 119, + name: 'Дніпро', + }, + name: 'Медікум', + }, + lastAddedPost: { + id: 246, + title: 'Sit amet consectetur', + }, + }, + { + id: 16, + firstName: 'Олег', + lastName: 'Петренко', + email: 'petrenko@mail.com', + qualification: 'Лікар вищої категорії', + phone: '+380957773377', + avatar: 'https://i.pravatar.cc/300?img=16', + bio: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit', + socialNetwork: 'https://www.youtube.com', + directions: [ + { + id: 6, + name: 'cardiology', + label: 'Кардіологія', + color: '#00ffff', + hasDoctors: true, + hasPosts: true, + }, + ], + mainInstitution: { + id: 5, + city: { + id: 55, + name: 'Бровари', + }, + name: 'Medical Idea', + }, + lastAddedPost: { + id: 266, + title: 'Офтальмонологія', + }, + }, +]; + +function setIntersectionObserver({ + root = null, + rootMargin = '', + thresholds = [], + disconnect = () => null, + observe = () => null, + takeRecords = () => [], + unobserve = () => null, +} = {}): void { + class MockIntersectionObserver implements IntersectionObserver { + readonly root: Element | null = root; + + readonly rootMargin: string = rootMargin; + + readonly thresholds: ReadonlyArray = thresholds; + + disconnect: () => void = disconnect; + + observe: (target: Element) => void = observe; + + takeRecords: () => IntersectionObserverEntry[] = takeRecords; + + unobserve: (target: Element) => void = unobserve; + } + + Object.defineProperty(window, 'IntersectionObserver', { + writable: true, + configurable: true, + value: MockIntersectionObserver, + }); + + Object.defineProperty(global, 'IntersectionObserver', { + writable: true, + configurable: true, + value: MockIntersectionObserver, + }); +} + +describe('AutoPaginationExpertsList component renders', () => { + beforeEach(() => { + setIntersectionObserver(); + render( + + + , + ); + }); + + it("Expert card renders with expert's full name", () => { + expect(screen.getByText('Марія Марієнко')).toBeInTheDocument(); + expect(screen.getByText('Палана Литвинова')).toBeInTheDocument(); + }); + + it("Expert card renders with expert's qualification and main institution", () => { + const element = document.querySelector('.ExpertDataCard-qualification-17'); + expect(element?.innerHTML).toContain( + 'Лікар вищої категорії, Medical Idea, Бровари', + ); + }); + + it('All expert cards render', () => { + expect(screen.getAllByRole('link').length).toBe(EXPERTS_LIST.length); + }); +}); diff --git a/src/old/modules/experts/components/__test__/ExpertInfo.test.tsx b/src/old/modules/experts/components/__test__/ExpertInfo.test.tsx new file mode 100644 index 000000000..5e8c6c2bf --- /dev/null +++ b/src/old/modules/experts/components/__test__/ExpertInfo.test.tsx @@ -0,0 +1,63 @@ +import React from 'react'; +import { screen, render } from '@testing-library/react'; +import { MemoryRouter } from 'react-router-dom'; +import { IExpert } from 'old/lib/types'; +import ExpertInfo from '../ExpertInfo'; + +const EXPERT_INFO_MOCK: IExpert = { + id: 1, + firstName: 'John', + lastName: 'Doe', + avatar: 'avatar', + phone: '+38(044)1111111', + email: 'j.doe@gmail.com', + bio: 'Lorem ipsum dolor sit amet', + socialNetwork: 'facebook/link', +}; + +const EXPERT_INFO_WITHOUT_CONTACTS_MOCK: IExpert = { + id: 2, + firstName: 'Linda', + lastName: 'Doe', + avatar: 'avatar', + phone: '+38(044)7777777', + bio: 'Lorem ipsum dolor sit amet consectur', +}; + +describe('ExpertsInfo component renders with all props', () => { + beforeEach(() => { + render( + + + , + ); + }); + + it('ExpertsInfo component renders full name', () => { + expect(screen.getByText('John Doe')).toBeInTheDocument(); + }); + + it('ExpertsInfo avatar renders', () => { + expect(screen.getByRole('img')).toBeInTheDocument(); + }); + + it('ExpertsInfo bio renders', () => { + expect(screen.getByText('Lorem ipsum dolor sit amet')).toBeInTheDocument(); + }); + + it("Expert's contact info renders", () => { + expect(screen.getByText('j.doe@gmail.com')).toBeInTheDocument(); + expect(screen.getByText('facebook/link')).toBeInTheDocument(); + }); +}); + +describe('Render ExpertInfo component without contact information', () => { + it('Render ExpertInfo without contact information', () => { + render( + + + , + ); + expect(screen.queryByText('j.doe@gmail.com')).toBeNull(); + }); +}); diff --git a/src/old/modules/experts/components/__test__/ExpertProfileView.test.tsx b/src/old/modules/experts/components/__test__/ExpertProfileView.test.tsx new file mode 100644 index 000000000..aa888a342 --- /dev/null +++ b/src/old/modules/experts/components/__test__/ExpertProfileView.test.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import { screen, render } from '@testing-library/react'; +import { Router } from 'react-router-dom'; +import { Provider } from 'react-redux'; +import { createMemoryHistory } from 'history'; +import { IExpert } from 'old/lib/types'; +import { store } from '../../../../../models/store'; +import ExpertProfileView from '../ExpertProfileView'; + +const history = createMemoryHistory(); + +const TEST_DATA: IExpert = { + id: 1, + firstName: 'John', + lastName: 'Doe', + avatar: 'avatar', + qualification: 'ophtalmology', + phone: '+38(044)7777777', + email: 'j.doe@gmail.com', + bio: 'Lorem ipsum dolor sit amet consectur', + socialNetwork: 'www.facebook.com', +}; + +describe('ExpertsProfileView component renders correctly', () => { + beforeEach(() => { + render( + + + + + , + ); + }); + + it('Expert full name renders', () => { + expect(screen.getByText('John Doe')).toBeInTheDocument(); + }); + + it('Expert avatar renders', () => { + expect(screen.getByRole('img')).toBeInTheDocument(); + }); + + it('Expert bio renders', () => { + expect( + screen.getByText('Lorem ipsum dolor sit amet consectur'), + ).toBeInTheDocument(); + }); +});