-
Notifications
You must be signed in to change notification settings - Fork 30
/
index.test.js
80 lines (71 loc) · 2.56 KB
/
index.test.js
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import React from 'react';
import numbro from 'numbro';
import NumberInput from './index';
import Enzyme, { shallow } from 'enzyme';
import Adapter from 'enzyme-adapter-react-16';
Enzyme.configure({ adapter: new Adapter() });
const testInitialFormat = states => {
const _test = (value, format, expected) =>
test(`value '${value}' formatted to '${format}' should display '${expected}'`, () => {
const component = shallow(<NumberInput value={value} format={format} />);
expect(component.find('input').props().value).toEqual(expected);
});
describe('initial render()', () => {
states.forEach(([value, format, expected]) =>
_test(value, format, expected));
});
};
testInitialFormat([
[null, '0,0', ''],
[null, '0,0.000', ''],
[0, '0,0', '0'],
[0, '0,0.000', '0.000'],
[1.234567, '0', '1'],
[1.234567, '0.00', '1.23'],
[1, '0,0', '1'],
[1000000, '0,0', '1,000,000'],
[-1000000, '0,0', '-1,000,000'],
[-1000000, '(0,0)', '(1,000,000)'],
['abcde', '0', ''],
['5m', '0,0', '5,000,000'],
['a123bcde', '0', '123'],
]);
const testOnChange = (value, arg, expected, format = '0,0') => {
describe(`simulate changing value = "${value}", expected = "${arg}", format = "${format}"`, () => {
test(`onChange to "${value}" passes "${arg}" as first argument`, () => {
const onChange = jest.fn();
const component = shallow(
<NumberInput
min={-1000}
max={1000000}
format={format}
value={1000}
onChange={onChange}
/>
);
component.find('input').simulate('change', { target: { value } });
expect(onChange).toBeCalledWith(arg, expect.anything());
});
test(`input renders ${expected} after onChange`, () => {
const component = shallow(
<NumberInput min={-1000} max={1000000} format={format} value={1000} />
);
component.find('input').simulate('change', { target: { value } });
component.find('input').simulate('blur', { target: { value } });
expect(component.find('input').props().value).toEqual(
expected == null || expected == ''
? ''
: numbro(expected).format(format)
);
});
});
};
// testOnChange(value, expectedArg, expectedDisplayValue, format)
testOnChange('', null, '');
testOnChange('123456', 123456, '123,456');
testOnChange('-123', -123, '-123');
testOnChange('asdf', null, '');
testOnChange('3.142', 3.14, '3.14', '0.00');
testOnChange('3.1427584', 3.14, '3.14', '0.00');
testOnChange('-50000', -1000, '-1,000', '0.00');
testOnChange('50000000', 1000000, '1,000,000', '0.00');