You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
209 lines
7.0 KiB
209 lines
7.0 KiB
import assert from 'assert'
|
|
import proxyquire from 'proxyquire'
|
|
import sinon from 'sinon'
|
|
|
|
let mapStateToProps
|
|
let mapDispatchToProps
|
|
let mergeProps
|
|
|
|
const actionSpies = {
|
|
showModal: sinon.spy(),
|
|
setGasPrice: sinon.spy(),
|
|
setGasTotal: sinon.spy(),
|
|
setGasLimit: sinon.spy(),
|
|
}
|
|
|
|
const sendDuckSpies = {
|
|
showGasButtonGroup: sinon.spy(),
|
|
}
|
|
|
|
const gasDuckSpies = {
|
|
resetCustomData: sinon.spy(),
|
|
setCustomGasPrice: sinon.spy(),
|
|
setCustomGasLimit: sinon.spy(),
|
|
}
|
|
|
|
proxyquire('../send-gas-row.container.js', {
|
|
'react-redux': {
|
|
connect: (ms, md, mp) => {
|
|
mapStateToProps = ms
|
|
mapDispatchToProps = md
|
|
mergeProps = mp
|
|
return () => ({})
|
|
},
|
|
},
|
|
'../../../../selectors/selectors': {
|
|
getCurrentEthBalance: (s) => `mockCurrentEthBalance:${s}`,
|
|
getAdvancedInlineGasShown: (s) => `mockAdvancedInlineGasShown:${s}`,
|
|
getSelectedToken: () => false,
|
|
},
|
|
'../../send.selectors.js': {
|
|
getConversionRate: (s) => `mockConversionRate:${s}`,
|
|
getCurrentCurrency: (s) => `mockConvertedCurrency:${s}`,
|
|
getGasTotal: (s) => `mockGasTotal:${s}`,
|
|
getGasPrice: (s) => `mockGasPrice:${s}`,
|
|
getGasLimit: (s) => `mockGasLimit:${s}`,
|
|
getSendAmount: (s) => `mockSendAmount:${s}`,
|
|
getSendFromBalance: (s) => `mockBalance:${s}`,
|
|
getTokenBalance: (s) => `mockTokenBalance:${s}`,
|
|
},
|
|
'../send-amount-row/amount-max-button/amount-max-button.selectors': {
|
|
getMaxModeOn: (s) => `mockMaxModeOn:${s}`,
|
|
},
|
|
'../../send.utils.js': {
|
|
isBalanceSufficient: ({
|
|
amount,
|
|
gasTotal,
|
|
balance,
|
|
conversionRate,
|
|
}) => `${amount}:${gasTotal}:${balance}:${conversionRate}`,
|
|
calcGasTotal: (gasLimit, gasPrice) => gasLimit + gasPrice,
|
|
},
|
|
'./send-gas-row.selectors.js': {
|
|
getGasLoadingError: (s) => `mockGasLoadingError:${s}`,
|
|
gasFeeIsInError: (s) => `mockGasFeeError:${s}`,
|
|
getGasButtonGroupShown: (s) => `mockGetGasButtonGroupShown:${s}`,
|
|
},
|
|
'../../../../store/actions': actionSpies,
|
|
'../../../../selectors/custom-gas': {
|
|
getBasicGasEstimateLoadingStatus: (s) => `mockBasicGasEstimateLoadingStatus:${s}`,
|
|
getRenderableEstimateDataForSmallButtonsFromGWEI: (s) => `mockGasButtonInfo:${s}`,
|
|
getDefaultActiveButtonIndex: (gasButtonInfo, gasPrice) => gasButtonInfo.length + gasPrice.length,
|
|
},
|
|
'../../../../ducks/send/send.duck': sendDuckSpies,
|
|
'../../../../ducks/gas/gas.duck': gasDuckSpies,
|
|
})
|
|
|
|
describe('send-gas-row container', () => {
|
|
|
|
describe('mapStateToProps()', () => {
|
|
|
|
it('should map the correct properties to props', () => {
|
|
assert.deepEqual(mapStateToProps('mockState'), {
|
|
balance: 'mockBalance:mockState',
|
|
conversionRate: 'mockConversionRate:mockState',
|
|
convertedCurrency: 'mockConvertedCurrency:mockState',
|
|
gasTotal: 'mockGasTotal:mockState',
|
|
gasFeeError: 'mockGasFeeError:mockState',
|
|
gasLoadingError: 'mockGasLoadingError:mockState',
|
|
gasPriceButtonGroupProps: {
|
|
buttonDataLoading: `mockBasicGasEstimateLoadingStatus:mockState`,
|
|
defaultActiveButtonIndex: 1,
|
|
newActiveButtonIndex: 49,
|
|
gasButtonInfo: `mockGasButtonInfo:mockState`,
|
|
},
|
|
gasButtonGroupShown: `mockGetGasButtonGroupShown:mockState`,
|
|
advancedInlineGasShown: 'mockAdvancedInlineGasShown:mockState',
|
|
gasLimit: 'mockGasLimit:mockState',
|
|
gasPrice: 'mockGasPrice:mockState',
|
|
insufficientBalance: false,
|
|
maxModeOn: 'mockMaxModeOn:mockState',
|
|
selectedToken: false,
|
|
tokenBalance: 'mockTokenBalance:mockState',
|
|
})
|
|
})
|
|
|
|
})
|
|
|
|
describe('mapDispatchToProps()', () => {
|
|
let dispatchSpy
|
|
let mapDispatchToPropsObject
|
|
|
|
beforeEach(() => {
|
|
dispatchSpy = sinon.spy()
|
|
mapDispatchToPropsObject = mapDispatchToProps(dispatchSpy)
|
|
actionSpies.setGasTotal.resetHistory()
|
|
})
|
|
|
|
describe('showCustomizeGasModal()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.showCustomizeGasModal()
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.deepEqual(
|
|
actionSpies.showModal.getCall(0).args[0],
|
|
{ name: 'CUSTOMIZE_GAS', hideBasic: true }
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('setGasPrice()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.setGasPrice('mockNewPrice', 'mockLimit')
|
|
assert(dispatchSpy.calledThrice)
|
|
assert(actionSpies.setGasPrice.calledOnce)
|
|
assert.equal(actionSpies.setGasPrice.getCall(0).args[0], 'mockNewPrice')
|
|
assert.equal(gasDuckSpies.setCustomGasPrice.getCall(0).args[0], 'mockNewPrice')
|
|
assert(actionSpies.setGasTotal.calledOnce)
|
|
assert.equal(actionSpies.setGasTotal.getCall(0).args[0], 'mockLimitmockNewPrice')
|
|
})
|
|
})
|
|
|
|
describe('setGasLimit()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.setGasLimit('mockNewLimit', 'mockPrice')
|
|
assert(dispatchSpy.calledThrice)
|
|
assert(actionSpies.setGasLimit.calledOnce)
|
|
assert.equal(actionSpies.setGasLimit.getCall(0).args[0], 'mockNewLimit')
|
|
assert.equal(gasDuckSpies.setCustomGasLimit.getCall(0).args[0], 'mockNewLimit')
|
|
assert(actionSpies.setGasTotal.calledOnce)
|
|
assert.equal(actionSpies.setGasTotal.getCall(0).args[0], 'mockNewLimitmockPrice')
|
|
})
|
|
})
|
|
|
|
describe('showGasButtonGroup()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.showGasButtonGroup()
|
|
assert(dispatchSpy.calledOnce)
|
|
assert(sendDuckSpies.showGasButtonGroup.calledOnce)
|
|
})
|
|
})
|
|
|
|
describe('resetCustomData()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.resetCustomData()
|
|
assert(dispatchSpy.calledOnce)
|
|
assert(gasDuckSpies.resetCustomData.calledOnce)
|
|
})
|
|
})
|
|
|
|
})
|
|
|
|
describe('mergeProps', () => {
|
|
let stateProps
|
|
let dispatchProps
|
|
let ownProps
|
|
|
|
beforeEach(() => {
|
|
stateProps = {
|
|
gasPriceButtonGroupProps: {
|
|
someGasPriceButtonGroupProp: 'foo',
|
|
anotherGasPriceButtonGroupProp: 'bar',
|
|
},
|
|
someOtherStateProp: 'baz',
|
|
}
|
|
dispatchProps = {
|
|
setGasPrice: sinon.spy(),
|
|
someOtherDispatchProp: sinon.spy(),
|
|
}
|
|
ownProps = { someOwnProp: 123 }
|
|
})
|
|
|
|
it('should return the expected props when isConfirm is true', () => {
|
|
const result = mergeProps(stateProps, dispatchProps, ownProps)
|
|
|
|
assert.equal(result.someOtherStateProp, 'baz')
|
|
assert.equal(result.gasPriceButtonGroupProps.someGasPriceButtonGroupProp, 'foo')
|
|
assert.equal(result.gasPriceButtonGroupProps.anotherGasPriceButtonGroupProp, 'bar')
|
|
assert.equal(result.someOwnProp, 123)
|
|
|
|
assert.equal(dispatchProps.setGasPrice.callCount, 0)
|
|
result.gasPriceButtonGroupProps.handleGasPriceSelection()
|
|
assert.equal(dispatchProps.setGasPrice.callCount, 1)
|
|
|
|
assert.equal(dispatchProps.someOtherDispatchProp.callCount, 0)
|
|
result.someOtherDispatchProp()
|
|
assert.equal(dispatchProps.someOtherDispatchProp.callCount, 1)
|
|
})
|
|
})
|
|
|
|
})
|
|
|