aboutsummaryrefslogtreecommitdiffstats
path: root/web/src/js/__tests__/components/FlowView/ToggleEditSpec.js
blob: ec3a8462bd0057fdc4f92830e62f549686e022c4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// jest.mock('../../../ducks/ui/flow')
import React from 'react'
import renderer from 'react-test-renderer'
import ToggleEdit from '../../../components/FlowView/ToggleEdit'
import { Provider } from 'react-redux'
import { startEdit, stopEdit } from '../../../ducks/ui/flow'
import { TFlow, TStore } from '../../ducks/tutils'

global.fetch = jest.fn()
let tflow = new TFlow()

describe('ToggleEdit Component', () => {
    let store = TStore(),
        provider = renderer.create(
        <Provider store={store}>
            <ToggleEdit/>
        </Provider>),
        tree = provider.toJSON()

    afterEach(() => { store.clearActions() })

    it('should render correctly', () => {
        expect(tree).toMatchSnapshot()
    })

    it('should handle click on stopEdit', () => {
        tree.children[0].props.onClick()
        expect(fetch).toBeCalled()
    })

    it('should handle click on startEdit', () => {
        store.getState().ui.flow.modifiedFlow = false
        let provider = renderer.create(
            <Provider store={store}>
                <ToggleEdit/>
            </Provider>),
            tree = provider.toJSON()
        tree.children[0].props.onClick()
        expect(store.getActions()).toEqual([startEdit(tflow)])
    })
})