|
1 | 1 | import React from 'react'; |
2 | | -import HashParserHOC from '../../../src/lib/hash-parser-hoc.jsx'; |
| 2 | +import configureStore from 'redux-mock-store'; |
3 | 3 | import {mount} from 'enzyme'; |
4 | 4 |
|
| 5 | +import HashParserHOC from '../../../src/lib/hash-parser-hoc.jsx'; |
| 6 | + |
5 | 7 | jest.mock('react-ga'); |
6 | 8 |
|
7 | 9 | describe('HashParserHOC', () => { |
| 10 | + const mockStore = configureStore(); |
| 11 | + let store; |
| 12 | + |
| 13 | + beforeEach(() => { |
| 14 | + store = mockStore({ |
| 15 | + scratchGui: { |
| 16 | + projectState: {} |
| 17 | + } |
| 18 | + }); |
| 19 | + }); |
| 20 | + |
8 | 21 | test('when there is a hash, it passes the hash as projectId', () => { |
9 | 22 | const Component = ({projectId}) => <div>{projectId}</div>; |
10 | 23 | const WrappedComponent = HashParserHOC(Component); |
11 | 24 | window.location.hash = '#1234567'; |
12 | | - const mounted = mount(<WrappedComponent />); |
13 | | - expect(mounted.state().projectId).toEqual('1234567'); |
| 25 | + const mockSetProjectIdFunc = jest.fn(); |
| 26 | + mount( |
| 27 | + <WrappedComponent |
| 28 | + setProjectId={mockSetProjectIdFunc} |
| 29 | + store={store} |
| 30 | + /> |
| 31 | + ); |
| 32 | + expect(mockSetProjectIdFunc.mock.calls[0][0]).toBe('1234567'); |
14 | 33 | }); |
15 | 34 |
|
16 | 35 | test('when there is no hash, it passes 0 as the projectId', () => { |
17 | 36 | const Component = ({projectId}) => <div>{projectId}</div>; |
18 | 37 | const WrappedComponent = HashParserHOC(Component); |
19 | 38 | window.location.hash = ''; |
20 | | - const mounted = mount(<WrappedComponent />); |
21 | | - expect(mounted.state().projectId).toEqual(0); |
| 39 | + const mockSetProjectIdFunc = jest.fn(); |
| 40 | + mount( |
| 41 | + <WrappedComponent |
| 42 | + setProjectId={mockSetProjectIdFunc} |
| 43 | + store={store} |
| 44 | + /> |
| 45 | + ); |
| 46 | + expect(mockSetProjectIdFunc.mock.calls[0][0]).toBe(0); |
22 | 47 | }); |
23 | 48 |
|
24 | 49 | test('when the hash is not a number, it passes 0 as projectId', () => { |
25 | 50 | const Component = ({projectId}) => <div>{projectId}</div>; |
26 | 51 | const WrappedComponent = HashParserHOC(Component); |
27 | 52 | window.location.hash = '#winning'; |
28 | | - const mounted = mount(<WrappedComponent />); |
29 | | - expect(mounted.state().projectId).toEqual(0); |
| 53 | + const mockSetProjectIdFunc = jest.fn(); |
| 54 | + mount( |
| 55 | + <WrappedComponent |
| 56 | + setProjectId={mockSetProjectIdFunc} |
| 57 | + store={store} |
| 58 | + /> |
| 59 | + ); |
| 60 | + expect(mockSetProjectIdFunc.mock.calls[0][0]).toBe(0); |
30 | 61 | }); |
31 | 62 |
|
32 | 63 | test('when hash change happens, the projectId state is changed', () => { |
33 | 64 | const Component = ({projectId}) => <div>{projectId}</div>; |
34 | 65 | const WrappedComponent = HashParserHOC(Component); |
35 | 66 | window.location.hash = ''; |
36 | | - const mounted = mount(<WrappedComponent />); |
37 | | - expect(mounted.state().projectId).toEqual(0); |
| 67 | + const mockSetProjectIdFunc = jest.fn(); |
| 68 | + const mounted = mount( |
| 69 | + <WrappedComponent |
| 70 | + setProjectId={mockSetProjectIdFunc} |
| 71 | + store={store} |
| 72 | + /> |
| 73 | + ); |
38 | 74 | window.location.hash = '#1234567'; |
39 | | - mounted.instance().handleHashChange(); |
40 | | - expect(mounted.state().projectId).toEqual('1234567'); |
| 75 | + mounted.childAt(0).instance().handleHashChange(); |
| 76 | + expect(mockSetProjectIdFunc.mock.calls.length).toBe(2); |
41 | 77 | }); |
42 | 78 | }); |
0 commit comments