Skip to content
This repository has been archived by the owner on Jan 9, 2023. It is now read-only.

Commit

Permalink
fix(test): update navbar tests for component update
Browse files Browse the repository at this point in the history
also refactored the test structure to improve organization, speed and remove code repetition

fix #1782
  • Loading branch information
ocBruno committed Feb 2, 2020
1 parent 25ddab7 commit 7cd00d8
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 66 deletions.
108 changes: 48 additions & 60 deletions src/__tests__/components/Navbar.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,115 +16,103 @@ describe('Navbar', () => {
</Router>,
)

const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

it('should render a HospitalRun Navbar', () => {
const wrapper = setup()
expect(wrapper.find(HospitalRunNavbar)).toHaveLength(1)
expect(hospitalRunNavbar).toHaveLength(1)
})

describe('brand', () => {
it('should render a HospitalRun Navbar with the navbar brand', () => {
const wrapper = setup()

expect(wrapper.find(HospitalRunNavbar).prop('brand').label).toEqual('HospitalRun')
describe('header', () => {
const header = wrapper.find('.nav-header')
it('should render a HospitalRun Navbar with the navbar header', () => {
expect(header.first().props().children.props.children).toEqual('HospitalRun')
})

it('should navigate to / when the brand is clicked', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

it('should navigate to / when the header is clicked', () => {
act(() => {
;(hospitalRunNavbar.prop('brand') as any).onClick()
header
.first()
.props()
.onClick()
})

expect(history.location.pathname).toEqual('/')
})
})

describe('patients', () => {
it('should render a patients dropdown', () => {
const wrapper = setup()

const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

expect(hospitalRunNavbar.prop('navLinks')[0].label).toEqual('patients.label')
expect(hospitalRunNavbar.prop('navLinks')[0].children[0].label).toEqual('actions.list')
expect(hospitalRunNavbar.prop('navLinks')[0].children[1].label).toEqual('actions.new')
const patientsLinkList = hospitalRunNavbar.find('.patients-link-list')
it('should render a patients link list', () => {
expect(patientsLinkList.first().props().title).toEqual('patients.label')
expect(patientsLinkList.first().props().children[0].props.children).toEqual('actions.list')
expect(patientsLinkList.first().props().children[1].props.children).toEqual('actions.new')
})

it('should navigate to /patients when the list option is selected', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

act(() => {
;(hospitalRunNavbar.prop('navLinks')[0].children[0] as any).onClick()
patientsLinkList
.first()
.props()
.children[0].props.onClick()
})

expect(history.location.pathname).toEqual('/patients')
})

it('should navigate to /patients/new when the list option is selected', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

act(() => {
;(hospitalRunNavbar.prop('navLinks')[0].children[1] as any).onClick()
patientsLinkList
.first()
.props()
.children[1].props.onClick()
})

expect(history.location.pathname).toEqual('/patients/new')
})
})

describe('scheduling', () => {
it('should render a scheduling dropdown', () => {
const wrapper = setup()
const scheduleLinkList = hospitalRunNavbar.find('.scheduling-link-list')

const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

expect(hospitalRunNavbar.prop('navLinks')[1].label).toEqual('scheduling.label')
expect(hospitalRunNavbar.prop('navLinks')[1].children[0].label).toEqual(
it('should render a scheduling dropdown', () => {
expect(scheduleLinkList.first().props().title).toEqual('scheduling.label')
expect(scheduleLinkList.first().props().children[0].props.children).toEqual(
'scheduling.appointments.label',
)
expect(hospitalRunNavbar.prop('navLinks')[1].children[1].label).toEqual(
expect(scheduleLinkList.first().props().children[1].props.children).toEqual(
'scheduling.appointments.new',
)
})

it('should navigate to to /appointments when the appointment list option is selected', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

act(() => {
;(hospitalRunNavbar.prop('navLinks')[1].children[0] as any).onClick()
scheduleLinkList
.first()
.props()
.children[0].props.onClick()
})

expect(history.location.pathname).toEqual('/appointments')
})

it('should navigate to /appointments/new when the new appointment list option is selected', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

act(() => {
;(hospitalRunNavbar.prop('navLinks')[1].children[1] as any).onClick()
scheduleLinkList
.first()
.props()
.children[1].props.onClick()
})

expect(history.location.pathname).toEqual('/appointments/new')
})
})

describe('search', () => {
it('should render Search as the search button label', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)

expect(hospitalRunNavbar.prop('search').buttonText).toEqual('actions.search')
})
const navSearch = hospitalRunNavbar.find('.nav-search')

it('should render Search as the search box placeholder', () => {
const wrapper = setup()
const hospitalRunNavbar = wrapper.find(HospitalRunNavbar)
expect(navSearch.at(2).props().children.props.children[0].props.placeholder).toEqual(
'actions.search',
)
})

expect(hospitalRunNavbar.prop('search').placeholderText).toEqual('actions.search')
it('should render Search as the search button label', () => {
expect(navSearch.at(2).props().children.props.children[1].props.children).toEqual(
'actions.search',
)
})
})
})
2 changes: 1 addition & 1 deletion src/__tests__/scheduling/appointments-slice.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,11 @@ import { AnyAction } from 'redux'
import Appointment from 'model/Appointment'
import { createMemoryHistory } from 'history'
import AppointmentRepository from 'clients/db/AppointmentsRepository'
import { mocked } from 'ts-jest/utils'
import appointments, {
createAppointmentStart,
createAppointment,
} from '../../scheduling/appointments/appointments-slice'
import { mocked } from 'ts-jest/utils'

describe('appointments slice', () => {
describe('appointments reducer', () => {
Expand Down
13 changes: 8 additions & 5 deletions src/components/Navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,23 @@ const Navbar = () => {
type: 'icon',
src:
'%0D%0AMy5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5r%0D%0AIiB2aWV3Qm94PSIwIDAgMjk5IDI5OSI+PGRlZnM+PHN0eWxlPi5jbHMtMXtmaWxsOnVybCgjbGlu%0D%0AZWFyLWdyYWRpZW50KTt9PC9zdHlsZT48bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVu%0D%0AdCIgeDE9IjcyLjU4IiB5MT0iMTYuMDQiIHgyPSIyMjcuMzEiIHkyPSIyODQuMDIiIGdyYWRpZW50%0D%0AVW5pdHM9InVzZXJTcGFjZU9uVXNlIj48c3RvcCBvZmZzZXQ9IjAuMDEiIHN0b3AtY29sb3I9IiM2%0D%0AMGQxYmIiLz48c3RvcCBvZmZzZXQ9IjAuNSIgc3RvcC1jb2xvcj0iIzFhYmM5YyIvPjxzdG9wIG9m%0D%0AZnNldD0iMSIgc3RvcC1jb2xvcj0iIzAwOWI5ZSIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjx0%0D%0AaXRsZT5jcm9zcy1pY29uPC90aXRsZT48cGF0aCBpZD0iY3Jvc3MiIGNsYXNzPSJjbHMtMSIgZD0i%0D%0ATTI5Mi45NCw5Ny40NkgyMDUuM1Y3LjA2QTYuNTYsNi41NiwwLDAsMCwxOTguNzQuNUgxMDEuMjZB%0D%0ANi41Niw2LjU2LDAsMCwwLDk0LjcsNy4wNnY5MC40SDcuMDZBNi41OCw2LjU4LDAsMCwwLC41LDEw%0D%0ANFYxOTYuM2E2LjIzLDYuMjMsMCwwLDAsNi4yMyw2LjI0aDg4djkwLjRhNi41Niw2LjU2LDAsMCww%0D%0ALDYuNTYsNi41Nmg5Ny40OGE2LjU2LDYuNTYsMCwwLDAsNi41Ni02LjU2di05MC40aDg4YTYuMjMs%0D%0ANi4yMywwLDAsMCw2LjIzLTYuMjRWMTA0QTYuNTgsNi41OCwwLDAsMCwyOTIuOTQsOTcuNDZaIiB0%0D%0AcmFuc2Zvcm09InRyYW5zbGF0ZSgtMC41IC0wLjUpIi8+PC9zdmc+',
onClick: () => undefined,
onClick: () => {
history.push('/')
},
className: 'nav-icon',
},
{
type: 'header',
label: 'HospitalRun',
onClick: () => {
history.push('/')
},
className: 'nav-header',
},
{
type: 'link-list',
label: t('patients.label'),
onClick: () => undefined,
className: 'patients-link-list',
children: [
{
type: 'link',
Expand All @@ -49,7 +53,7 @@ const Navbar = () => {
{
type: 'link-list',
label: t('scheduling.label'),
onClick: () => undefined,
className: 'scheduling-link-list',
children: [
{
type: 'link',
Expand All @@ -70,15 +74,14 @@ const Navbar = () => {
{
type: 'search',
placeholderText: t('actions.search'),
className: 'ml-auto',
className: 'ml-auto nav-search',
buttonText: t('actions.search'),
buttonColor: 'secondary',
onClickButton: () => undefined,
onChangeInput: () => undefined,
},
]}
/>

)
}

Expand Down

0 comments on commit 7cd00d8

Please sign in to comment.