2021-02-04 19:15:23 +01:00
|
|
|
import React from 'react';
|
|
|
|
import { shallow } from 'enzyme';
|
|
|
|
import sinon from 'sinon';
|
2021-03-16 22:00:08 +01:00
|
|
|
import AmountMaxButton from './amount-max-button.component';
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
describe('AmountMaxButton Component', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
let wrapper;
|
|
|
|
let instance;
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2020-02-11 21:33:32 +01:00
|
|
|
const propsMethodSpies = {
|
|
|
|
setAmountToMax: sinon.spy(),
|
|
|
|
setMaxModeTo: sinon.spy(),
|
2021-02-04 19:15:23 +01:00
|
|
|
};
|
2020-02-11 21:33:32 +01:00
|
|
|
|
2021-02-04 19:15:23 +01:00
|
|
|
const MOCK_EVENT = { preventDefault: () => undefined };
|
2020-02-11 21:33:32 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
beforeAll(() => {
|
2021-02-04 19:15:23 +01:00
|
|
|
sinon.spy(AmountMaxButton.prototype, 'setMaxAmount');
|
|
|
|
});
|
2020-02-11 21:33:32 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
beforeEach(() => {
|
2020-11-03 00:41:28 +01:00
|
|
|
wrapper = shallow(
|
2019-12-03 17:35:44 +01:00
|
|
|
<AmountMaxButton
|
|
|
|
balance="mockBalance"
|
|
|
|
gasTotal="mockGasTotal"
|
|
|
|
maxModeOn={false}
|
2020-11-03 00:41:28 +01:00
|
|
|
sendToken={{ address: 'mockTokenAddress' }}
|
2019-12-03 17:35:44 +01:00
|
|
|
setAmountToMax={propsMethodSpies.setAmountToMax}
|
|
|
|
setMaxModeTo={propsMethodSpies.setMaxModeTo}
|
|
|
|
tokenBalance="mockTokenBalance"
|
2020-11-03 00:41:28 +01:00
|
|
|
/>,
|
|
|
|
{
|
|
|
|
context: {
|
|
|
|
t: (str) => `${str}_t`,
|
|
|
|
metricsEvent: () => undefined,
|
|
|
|
},
|
2019-05-07 18:12:14 +02:00
|
|
|
},
|
2021-02-04 19:15:23 +01:00
|
|
|
);
|
|
|
|
instance = wrapper.instance();
|
|
|
|
});
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
afterEach(() => {
|
2021-02-04 19:15:23 +01:00
|
|
|
propsMethodSpies.setAmountToMax.resetHistory();
|
|
|
|
propsMethodSpies.setMaxModeTo.resetHistory();
|
|
|
|
AmountMaxButton.prototype.setMaxAmount.resetHistory();
|
|
|
|
});
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
afterAll(() => {
|
2021-02-04 19:15:23 +01:00
|
|
|
sinon.restore();
|
|
|
|
});
|
2020-02-11 21:33:32 +01:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
describe('setMaxAmount', () => {
|
|
|
|
it('should call setAmountToMax with the correct params', () => {
|
|
|
|
expect(propsMethodSpies.setAmountToMax.callCount).toStrictEqual(0);
|
2021-02-04 19:15:23 +01:00
|
|
|
instance.setMaxAmount();
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(propsMethodSpies.setAmountToMax.callCount).toStrictEqual(1);
|
|
|
|
expect(propsMethodSpies.setAmountToMax.getCall(0).args).toStrictEqual([
|
2020-11-03 00:41:28 +01:00
|
|
|
{
|
2018-05-14 11:25:03 +02:00
|
|
|
balance: 'mockBalance',
|
|
|
|
gasTotal: 'mockGasTotal',
|
2020-05-29 19:46:10 +02:00
|
|
|
sendToken: { address: 'mockTokenAddress' },
|
2018-05-14 11:25:03 +02:00
|
|
|
tokenBalance: 'mockTokenBalance',
|
2020-11-03 00:41:28 +01:00
|
|
|
},
|
2021-02-04 19:15:23 +01:00
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
describe('render', () => {
|
|
|
|
it('should render an element with a send-v2__amount-max class', () => {
|
|
|
|
expect(wrapper.find('.send-v2__amount-max')).toHaveLength(1);
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should call setMaxModeTo and setMaxAmount when the checkbox is checked', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
const { onClick } = wrapper.find('.send-v2__amount-max').props();
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(AmountMaxButton.prototype.setMaxAmount.callCount).toStrictEqual(0);
|
|
|
|
expect(propsMethodSpies.setMaxModeTo.callCount).toStrictEqual(0);
|
2021-02-04 19:15:23 +01:00
|
|
|
onClick(MOCK_EVENT);
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(AmountMaxButton.prototype.setMaxAmount.callCount).toStrictEqual(1);
|
|
|
|
expect(propsMethodSpies.setMaxModeTo.callCount).toStrictEqual(1);
|
|
|
|
expect(propsMethodSpies.setMaxModeTo.getCall(0).args).toStrictEqual([
|
2020-12-03 16:46:22 +01:00
|
|
|
true,
|
2021-02-04 19:15:23 +01:00
|
|
|
]);
|
|
|
|
});
|
2018-05-14 11:25:03 +02:00
|
|
|
|
2021-04-15 20:01:46 +02:00
|
|
|
it('should render the expected text when maxModeOn is false', () => {
|
2021-02-04 19:15:23 +01:00
|
|
|
wrapper.setProps({ maxModeOn: false });
|
2021-04-15 20:01:46 +02:00
|
|
|
expect(wrapper.find('.send-v2__amount-max').text()).toStrictEqual(
|
|
|
|
'max_t',
|
|
|
|
);
|
2021-02-04 19:15:23 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|