-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(workflow-context): attach additional properties and tests (#22)
* refactor: split approval-status into state and alllowed-actions * fix: add params to workflow-provider value * refactor: rename use-approval-state to get-tag-display-data * test: add unit tests for get-tag-display-data * test(workflow-context): add unit tests for workflow context
- Loading branch information
1 parent
22fd9bd
commit 407ebf8
Showing
12 changed files
with
348 additions
and
62 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
import { getTagDisplayData } from './get-tag-display-data.js' | ||
import { Approved, Ready, Waiting } from './icons.js' | ||
|
||
describe('getTagDisplayData', () => { | ||
it('returns "approved" display data for the correct approval states', () => { | ||
const expectedDisplayData = { | ||
icon: Approved, | ||
displayName: 'Approved', | ||
type: 'positive', | ||
} | ||
expect(getTagDisplayData('APPROVED_HERE')).toEqual(expectedDisplayData) | ||
expect(getTagDisplayData('APPROVED_ELSEWHERE')).toEqual( | ||
expectedDisplayData | ||
) | ||
}) | ||
it('returns "ready for approval and accepted" display data for the correct approval states', () => { | ||
const expectedDisplayData = { | ||
icon: Ready, | ||
displayName: 'Ready for approval and accepted', | ||
type: 'neutral', | ||
} | ||
expect(getTagDisplayData('ACCEPTED_HERE')).toEqual(expectedDisplayData) | ||
expect(getTagDisplayData('ACCEPTED_ELSEWHERE')).toEqual( | ||
expectedDisplayData | ||
) | ||
}) | ||
it('returns "ready for approval" display data for the correct approval states', () => { | ||
const expectedDisplayData = { | ||
icon: Ready, | ||
displayName: 'Ready for approval', | ||
type: 'neutral', | ||
} | ||
expect(getTagDisplayData('UNAPPROVED_READY')).toEqual( | ||
expectedDisplayData | ||
) | ||
}) | ||
it('returns "waiting" display data for the correct approval states', () => { | ||
const expectedDisplayData = { | ||
icon: Waiting, | ||
displayName: 'Waiting', | ||
type: 'default', | ||
} | ||
expect(getTagDisplayData('UNAPPROVED_WAITING')).toEqual( | ||
expectedDisplayData | ||
) | ||
expect(getTagDisplayData('UNAPPROVED_ELSEWHERE')).toEqual( | ||
expectedDisplayData | ||
) | ||
expect(getTagDisplayData('UNAPPROVED_ABOVE')).toEqual( | ||
expectedDisplayData | ||
) | ||
}) | ||
it('returns "cannot approve" display data for the correct approval states', () => { | ||
const expectedDisplayData = { | ||
icon: Waiting, | ||
displayName: 'Cannot approve', | ||
type: 'negative', | ||
} | ||
expect(getTagDisplayData('UNAPPROVABLE')).toEqual(expectedDisplayData) | ||
}) | ||
it('throws an error when encountering an unknown approval state', () => { | ||
expect(() => getTagDisplayData('bad input')).toThrow( | ||
"Unknown approval state: 'bad input'" | ||
) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
import { useAppContext } from '../app-context/index.js' | ||
import { useSelectedWorkflow } from './use-selected-workflow.js' | ||
|
||
const mockWorkflows = [ | ||
{ | ||
displayName: 'Workflow a', | ||
id: 'i5m0JPw4DQi', | ||
periodType: 'Daily', | ||
}, | ||
{ | ||
displayName: 'Workflow B', | ||
id: 'rIUL3hYOjJc', | ||
periodType: 'Daily', | ||
}, | ||
] | ||
|
||
jest.mock('../app-context/index.js', () => ({ | ||
useAppContext: jest.fn(() => ({ | ||
dataApprovalWorkflows: mockWorkflows, | ||
})), | ||
})) | ||
|
||
describe('useSelectedWorkflow', () => { | ||
it('returns the selected workflow if params.wf matches a workflow id', () => { | ||
expect(useSelectedWorkflow({ wf: 'i5m0JPw4DQi' })).toBe( | ||
mockWorkflows[0] | ||
) | ||
}) | ||
it('returns an empty object if params.wf does not match the id of any workflows', () => { | ||
expect(useSelectedWorkflow({ wf: 'badID' })).toEqual({}) | ||
}) | ||
it('returns an empty object if params.wf is undefined', () => { | ||
expect(useSelectedWorkflow({ wf: undefined })).toEqual({}) | ||
expect(useSelectedWorkflow()).toEqual({}) | ||
}) | ||
it('returns an empty object if no workflows are found', () => { | ||
useAppContext.mockImplementationOnce(() => ({ | ||
dataApprovalWorkflows: [], | ||
})) | ||
expect(useSelectedWorkflow({ wf: 'i5m0JPw4DQi' })).toEqual({}) | ||
}) | ||
it('returns an empty object if workflows are undefined', () => { | ||
useAppContext.mockImplementationOnce(() => ({})) | ||
expect(useSelectedWorkflow({ wf: 'i5m0JPw4DQi' })).toEqual({}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
import { act, renderHook } from '@testing-library/react-hooks' | ||
import React from 'react' | ||
import { history } from '../navigation/history.js' | ||
import { readQueryParams } from '../navigation/read-query-params.js' | ||
import { | ||
useSelectionParams, | ||
getParamsIfAllAvailable, | ||
} from './use-selection-params.js' | ||
import { WorkflowProvider } from './workflow-provider.js' | ||
|
||
jest.mock('../navigation/read-query-params.js', () => ({ | ||
readQueryParams: jest.fn(() => ({})), | ||
})) | ||
|
||
describe('useSelectionParams', () => { | ||
const wrapper = ({ children }) => ( | ||
<WorkflowProvider>{children}</WorkflowProvider> | ||
) | ||
it('responds to history changes', () => { | ||
const spy = jest.spyOn(history, 'listen') | ||
renderHook(() => useSelectionParams(), { wrapper }) | ||
|
||
act(() => { | ||
history.push({ | ||
pathname: '/', | ||
search: `?wf=123&pe=456&ou=789`, | ||
}) | ||
}) | ||
|
||
expect(spy).toHaveBeenCalledTimes(1) | ||
}) | ||
}) | ||
|
||
describe('getParamsIfAllAvailable', () => { | ||
it('returns an object if all required query params are found', () => { | ||
readQueryParams.mockImplementationOnce(() => ({ | ||
wf: '123', | ||
pe: '123', | ||
ou: '/123/456', | ||
})) | ||
expect(getParamsIfAllAvailable()).toEqual({ | ||
ou: '456', | ||
pe: '123', | ||
wf: '123', | ||
}) | ||
}) | ||
it('returns null if query params are only partially complete', () => { | ||
readQueryParams.mockImplementationOnce(() => ({ | ||
wf: '123', | ||
pe: '123', | ||
})) | ||
expect(getParamsIfAllAvailable()).toEqual(null) | ||
}) | ||
it('returns null if no query params are found', () => { | ||
readQueryParams.mockImplementationOnce(() => ({})) | ||
expect(getParamsIfAllAvailable()).toEqual(null) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
import { renderHook } from '@testing-library/react-hooks' | ||
import React from 'react' | ||
import { useWorkflowContext } from './use-workflow-context.js' | ||
import { WorkflowProvider } from './workflow-provider.js' | ||
|
||
jest.mock('./use-selection-params.js', () => ({ | ||
useSelectionParams: jest.fn(() => ({ | ||
wf: 'rIUL3hYOjJc', | ||
pe: '20120404', | ||
ou: '456', | ||
})), | ||
})) | ||
|
||
jest.mock('./use-selected-workflow.js', () => ({ | ||
useSelectedWorkflow: jest.fn(() => ({ | ||
displayName: 'Workflow a', | ||
id: 'i5m0JPw4DQi', | ||
periodType: 'Daily', | ||
dataSets: [{ id: '123', displayName: 'Dataset Z' }], | ||
})), | ||
})) | ||
|
||
jest.mock('@dhis2/app-runtime', () => ({ | ||
useDataQuery: jest.fn(() => ({ | ||
loading: false, | ||
error: null, | ||
data: { | ||
approvalStatus: { | ||
state: 'SOME_STATE_LABEL', | ||
canApprove: true, | ||
}, | ||
}, | ||
called: true, | ||
refetch: () => {}, | ||
})), | ||
})) | ||
|
||
describe('useWorkflowContext', () => { | ||
const wrapper = ({ children }) => ( | ||
<WorkflowProvider>{children}</WorkflowProvider> | ||
) | ||
it('combines data from various hooks', () => { | ||
const { result } = renderHook(() => useWorkflowContext(), { wrapper }) | ||
|
||
expect(result.current).toEqual({ | ||
allowedActions: { | ||
canApprove: true, | ||
}, | ||
approvalState: 'SOME_STATE_LABEL', | ||
dataSets: [ | ||
{ | ||
displayName: 'Dataset Z', | ||
id: '123', | ||
}, | ||
], | ||
displayName: 'Workflow a', | ||
params: { | ||
ou: '456', | ||
pe: '20120404', | ||
wf: 'rIUL3hYOjJc', | ||
}, | ||
}) | ||
}) | ||
}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.