From ae71ec1d30d58d164c3c86cf0105968d08dc1b82 Mon Sep 17 00:00:00 2001 From: Matthew Shao Date: Tue, 28 Mar 2017 20:44:49 +0800 Subject: [PATCH] [web] Coverage++ for ducks/flows.js --- web/src/js/__tests__/ducks/flowsSpec.js | 161 +++++++++++++++++++++++- 1 file changed, 158 insertions(+), 3 deletions(-) diff --git a/web/src/js/__tests__/ducks/flowsSpec.js b/web/src/js/__tests__/ducks/flowsSpec.js index acfa308372..185e12bbd3 100644 --- a/web/src/js/__tests__/ducks/flowsSpec.js +++ b/web/src/js/__tests__/ducks/flowsSpec.js @@ -1,14 +1,14 @@ jest.unmock('../../ducks/flows'); +jest.mock('../../utils') import reduceFlows, * as flowActions from '../../ducks/flows' -import * as storeActions from '../../ducks/utils/store' - +import reduceStore from '../../ducks/utils/store' describe('select flow', () => { let state = reduceFlows(undefined, {}) for (let i of [1, 2, 3, 4]) { - state = reduceFlows(state, storeActions.add({ id: i })) + state = reduceFlows(state, {type: flowActions.ADD, data: {id: i}, cmd: 'add'}) } it('should be possible to select a single flow', () => { @@ -28,4 +28,159 @@ describe('select flow', () => { } ) }) + + it('should be possible to select relative',() => { + // already selected some flows + let newState = {}, + getState = () => { return { flows: {...state, selected: [2]}}}, + dispatch = (action) => { newState = reduceFlows(getState().flows, action) } + flowActions.selectRelative(1)(dispatch, getState) + expect(newState).toEqual({...state, selected: [3]}) + + // haven't selected any flow + getState = () => { return { flows: { ...state, selected: []}}} + flowActions.selectRelative(-1)(dispatch, getState) + expect(newState).toEqual({...state, selected: [1]}) + }) +}) + +describe('flows reducer', () => { + it('should return initial state', () => { + expect(reduceFlows(undefined, {})).toEqual({ + highlight: null, + filter: null, + sort: { column: null, desc: false }, + selected: [], + ...reduceStore(undefined, {}) + }) + }) + + it('should be possible to set filter', () => { + let filt = "~u 123" + expect(reduceFlows(undefined, flowActions.setFilter(filt)).filter).toEqual(filt) + }) + + it('should be possible to set highlight', () => { + let key = "foo" + expect(reduceFlows(undefined, flowActions.setHighlight(key)).highlight).toEqual(key) + }) + + it('should be possilbe to set sort', () => { + let sort = { column: "TLSColumn", desc: 1 } + expect(reduceFlows(undefined, flowActions.setSort(sort.column, sort.desc)).sort).toEqual(sort) + }) + + it('should update state.selected on remove', () => { + let state = reduceFlows(undefined, {}) + for (let i of [1, 2, 3, 4]) { + state = reduceFlows(state, {type: flowActions.ADD, data: {id: i}, cmd: 'add'}) + } + state = reduceFlows(state, flowActions.select(2)) + expect(reduceFlows(state, {type: flowActions.REMOVE, data: 2, cmd: 'remove'}).selected).toEqual([3]) + //last row + state = reduceFlows(state, flowActions.select(4)) + expect(reduceFlows(state, {type: flowActions.REMOVE, data: 4, cmd: 'remove'}).selected).toEqual([3]) + }) +}) + +describe('flows actions', () => { + + let tflow = { id: 1 } + it('should handle resume action', () => { + flowActions.resume(tflow)() + }) + + it('should handle resumeAll action', () => { + flowActions.resumeAll()() + }) + + it('should handle kill action', () => { + flowActions.kill(tflow)() + }) + + it('should handle killAll action', () => { + flowActions.killAll()() + }) + + it('should handle remove action', () => { + flowActions.remove(tflow)() + }) + + it('should handle duplicate action', () => { + flowActions.duplicate(tflow)() + }) + + it('should handle replay action', () => { + flowActions.replay(tflow)() + }) + + it('should handle revert action', () => { + flowActions.revert(tflow)() + }) + + it('should handle update action', () => { + flowActions.update(tflow, "foo")() + }) + + it('should handle updateContent action', () => { + flowActions.uploadContent(tflow, "foo", "foo")() + }) + + it('should hanlde clear action', () => { + flowActions.clear()() + }) + + it('should handle download action', () => { + let state = reduceFlows(undefined, {}) + expect(reduceFlows(state, flowActions.download())).toEqual(state) + }) + + it('should handle upload action', () => { + flowActions.upload("foo")() + }) +}) + +describe('makeSort', () => { + it('should be possible to sort by TLSColumn', () => { + let sort = flowActions.makeSort({column: 'TLSColumn', desc:true}), + a = {request: {scheme: 'http'}}, + b = {request: {scheme: 'https'}} + expect(sort(a, b)).toEqual(1) + }) + + it('should be possible to sort by PathColumn', () => { + let sort = flowActions.makeSort({column: 'PathColumn', desc:true}), + a = {request: {}}, + b = {request: {}} + expect(sort(a, b)).toEqual(0) + + }) + + it('should be possible to sort by MethodColumn', () => { + let sort = flowActions.makeSort({column: 'MethodColumn', desc:true}), + a = {request: {method: 'GET'}}, + b = {request: {method: 'POST'}} + expect(sort(b, a)).toEqual(-1) + }) + + it('should be possible to sort by StatusColumn', () => { + let sort = flowActions.makeSort({column: 'StatusColumn', desc:false}), + a = {response: {status_code: 200}}, + b = {response: {status_code: 404}} + expect(sort(a, b)).toEqual(-1) + }) + + it('should be possible to sort by TimeColumn', () => { + let sort = flowActions.makeSort({column: 'TimeColumn', desc: false}), + a = {response: {timestamp_end: 9}, request: {timestamp_start: 8}}, + b = {response: {timestamp_end: 10}, request: {timestamp_start: 8}} + expect(sort(b, a)).toEqual(1) + }) + + it('should be possible to sort by SizeColumn', () => { + let sort = flowActions.makeSort({column:'SizeColumn', desc: true}), + a = {request: {contentLength: 1}, response: {contentLength: 1}}, + b = {request: {contentLength: 1}} + expect(sort(a, b)).toEqual(-1) + }) })