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

Commit

Permalink
refactor(labs): refactor labs module to use react query (#2410)
Browse files Browse the repository at this point in the history
  • Loading branch information
rsousaj authored Sep 26, 2020
1 parent 6647e37 commit c1b850e
Show file tree
Hide file tree
Showing 32 changed files with 821 additions and 1,065 deletions.
51 changes: 22 additions & 29 deletions src/__tests__/labs/Labs.test.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { act } from '@testing-library/react'
import { mount, ReactWrapper } from 'enzyme'
import React from 'react'
import { Provider } from 'react-redux'
Expand Down Expand Up @@ -28,62 +29,54 @@ describe('Labs', () => {
jest
.spyOn(PatientRepository, 'find')
.mockResolvedValue({ id: '12345', fullName: 'test test' } as Patient)
const setup = (route: string, permissions: Permissions[] = []) => {

const setup = async (initialEntry: string, permissions: Permissions[] = []) => {
const store = mockStore({
user: { permissions },
breadcrumbs: { breadcrumbs: [] },
components: { sidebarCollapsed: false },
lab: {
lab: ({
id: '1234',
patientId: 'patientId',
requestedOn: new Date().toISOString(),
} as unknown) as Lab,
patient: { id: 'patientId', fullName: 'some name' },
error: {},
},
} as any)

const wrapper = mount(
<Provider store={store}>
<MemoryRouter initialEntries={[route]}>
<TitleProvider>
<Labs />
</TitleProvider>
</MemoryRouter>
</Provider>,
)
let wrapper: any
await act(async () => {
wrapper = await mount(
<Provider store={store}>
<MemoryRouter initialEntries={[initialEntry]}>
<TitleProvider>
<Labs />
</TitleProvider>
</MemoryRouter>
</Provider>,
)
})

wrapper.update()
return { wrapper: wrapper as ReactWrapper }
}

describe('routing', () => {
describe('/labs/new', () => {
it('should render the new lab request screen when /labs/new is accessed', () => {
const permissions: Permissions[] = [Permissions.RequestLab]
const { wrapper } = setup('/labs/new', permissions)
it('should render the new lab request screen when /labs/new is accessed', async () => {
const { wrapper } = await setup('/labs/new', [Permissions.RequestLab])

expect(wrapper.find(NewLabRequest)).toHaveLength(1)
})

it('should not navigate to /labs/new if the user does not have RequestLab permissions', () => {
const { wrapper } = setup('/labs/new')
it('should not navigate to /labs/new if the user does not have RequestLab permissions', async () => {
const { wrapper } = await setup('/labs/new')

expect(wrapper.find(NewLabRequest)).toHaveLength(0)
})
})

describe('/labs/:id', () => {
it('should render the view lab screen when /labs/:id is accessed', async () => {
const permissions: Permissions[] = [Permissions.ViewLab]
const { wrapper } = setup('/labs/1234', permissions)
const { wrapper } = await setup('/labs/1234', [Permissions.ViewLab])

expect(wrapper.find(ViewLab)).toHaveLength(1)
})
})

it('should not navigate to /labs/:id if the user does not have ViewLab permissions', async () => {
const { wrapper } = setup('/labs/1234')
const { wrapper } = await setup('/labs/1234')

expect(wrapper.find(ViewLab)).toHaveLength(0)
})
Expand Down
Loading

1 comment on commit c1b850e

@vercel
Copy link

@vercel vercel bot commented on c1b850e Sep 26, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.