mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
b3d78ed8a1
Revert accidentally changed constants. Require defaults in ens-input, gas-fee-display and confirm screens.
170 lines
5.4 KiB
JavaScript
170 lines
5.4 KiB
JavaScript
import assert from 'assert'
|
|
import proxyquire from 'proxyquire'
|
|
import sinon from 'sinon'
|
|
|
|
let mapStateToProps
|
|
let mapDispatchToProps
|
|
|
|
const actionSpies = {
|
|
updateSendTokenBalance: sinon.spy(),
|
|
updateGasData: sinon.spy(),
|
|
setGasTotal: sinon.spy(),
|
|
}
|
|
const duckActionSpies = {
|
|
updateSendErrors: sinon.spy(),
|
|
resetSendState: sinon.spy(),
|
|
}
|
|
|
|
proxyquire('../send.container.js', {
|
|
'react-redux': {
|
|
connect: (ms, md) => {
|
|
mapStateToProps = ms
|
|
mapDispatchToProps = md
|
|
return () => ({})
|
|
},
|
|
},
|
|
'react-router-dom': { withRouter: () => {} },
|
|
'recompose': { compose: (arg1, arg2) => () => arg2() },
|
|
'./send.selectors': {
|
|
getAmountConversionRate: (s) => `mockAmountConversionRate:${s}`,
|
|
getBlockGasLimit: (s) => `mockBlockGasLimit:${s}`,
|
|
getConversionRate: (s) => `mockConversionRate:${s}`,
|
|
getCurrentNetwork: (s) => `mockNetwork:${s}`,
|
|
getGasLimit: (s) => `mockGasLimit:${s}`,
|
|
getGasPrice: (s) => `mockGasPrice:${s}`,
|
|
getGasTotal: (s) => `mockGasTotal:${s}`,
|
|
getPrimaryCurrency: (s) => `mockPrimaryCurrency:${s}`,
|
|
getRecentBlocks: (s) => `mockRecentBlocks:${s}`,
|
|
getSelectedAddress: (s) => `mockSelectedAddress:${s}`,
|
|
getSelectedToken: (s) => `mockSelectedToken:${s}`,
|
|
getSelectedTokenContract: (s) => `mockTokenContract:${s}`,
|
|
getSelectedTokenToFiatRate: (s) => `mockTokenToFiatRate:${s}`,
|
|
getSendAmount: (s) => `mockAmount:${s}`,
|
|
getSendTo: (s) => `mockTo:${s}`,
|
|
getSendEditingTransactionId: (s) => `mockEditingTransactionId:${s}`,
|
|
getSendFromObject: (s) => `mockFrom:${s}`,
|
|
getTokenBalance: (s) => `mockTokenBalance:${s}`,
|
|
},
|
|
'../../actions': actionSpies,
|
|
'../../ducks/send.duck': duckActionSpies,
|
|
'./send.utils.js': {
|
|
calcGasTotal: (gasLimit, gasPrice) => gasLimit + gasPrice,
|
|
},
|
|
})
|
|
|
|
describe('send container', () => {
|
|
|
|
describe('mapStateToProps()', () => {
|
|
|
|
it('should map the correct properties to props', () => {
|
|
assert.deepEqual(mapStateToProps('mockState'), {
|
|
amount: 'mockAmount:mockState',
|
|
amountConversionRate: 'mockAmountConversionRate:mockState',
|
|
blockGasLimit: 'mockBlockGasLimit:mockState',
|
|
conversionRate: 'mockConversionRate:mockState',
|
|
editingTransactionId: 'mockEditingTransactionId:mockState',
|
|
from: 'mockFrom:mockState',
|
|
gasLimit: 'mockGasLimit:mockState',
|
|
gasPrice: 'mockGasPrice:mockState',
|
|
gasTotal: 'mockGasTotal:mockState',
|
|
network: 'mockNetwork:mockState',
|
|
primaryCurrency: 'mockPrimaryCurrency:mockState',
|
|
recentBlocks: 'mockRecentBlocks:mockState',
|
|
selectedAddress: 'mockSelectedAddress:mockState',
|
|
selectedToken: 'mockSelectedToken:mockState',
|
|
to: 'mockTo:mockState',
|
|
tokenBalance: 'mockTokenBalance:mockState',
|
|
tokenContract: 'mockTokenContract:mockState',
|
|
tokenToFiatRate: 'mockTokenToFiatRate:mockState',
|
|
})
|
|
})
|
|
|
|
})
|
|
|
|
describe('mapDispatchToProps()', () => {
|
|
let dispatchSpy
|
|
let mapDispatchToPropsObject
|
|
|
|
beforeEach(() => {
|
|
dispatchSpy = sinon.spy()
|
|
mapDispatchToPropsObject = mapDispatchToProps(dispatchSpy)
|
|
})
|
|
|
|
describe('updateAndSetGasTotal()', () => {
|
|
const mockProps = {
|
|
blockGasLimit: 'mockBlockGasLimit',
|
|
editingTransactionId: '0x2',
|
|
gasLimit: '0x3',
|
|
gasPrice: '0x4',
|
|
recentBlocks: ['mockBlock'],
|
|
selectedAddress: '0x4',
|
|
selectedToken: { address: '0x1' },
|
|
to: 'mockTo',
|
|
value: 'mockValue',
|
|
}
|
|
|
|
it('should dispatch a setGasTotal action when editingTransactionId is truthy', () => {
|
|
mapDispatchToPropsObject.updateAndSetGasTotal(mockProps)
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.equal(
|
|
actionSpies.setGasTotal.getCall(0).args[0],
|
|
'0x30x4'
|
|
)
|
|
})
|
|
|
|
it('should dispatch an updateGasData action when editingTransactionId is falsy', () => {
|
|
const { selectedAddress, selectedToken, recentBlocks, blockGasLimit, to, value } = mockProps
|
|
mapDispatchToPropsObject.updateAndSetGasTotal(
|
|
Object.assign({}, mockProps, {editingTransactionId: false})
|
|
)
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.deepEqual(
|
|
actionSpies.updateGasData.getCall(0).args[0],
|
|
{ selectedAddress, selectedToken, recentBlocks, blockGasLimit, to, value }
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('updateSendTokenBalance()', () => {
|
|
const mockProps = {
|
|
address: '0x10',
|
|
tokenContract: '0x00a',
|
|
selectedToken: {address: '0x1'},
|
|
}
|
|
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.updateSendTokenBalance(Object.assign({}, mockProps))
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.deepEqual(
|
|
actionSpies.updateSendTokenBalance.getCall(0).args[0],
|
|
mockProps
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('updateSendErrors()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.updateSendErrors('mockError')
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.equal(
|
|
duckActionSpies.updateSendErrors.getCall(0).args[0],
|
|
'mockError'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('resetSendState()', () => {
|
|
it('should dispatch an action', () => {
|
|
mapDispatchToPropsObject.resetSendState()
|
|
assert(dispatchSpy.calledOnce)
|
|
assert.equal(
|
|
duckActionSpies.resetSendState.getCall(0).args.length,
|
|
0
|
|
)
|
|
})
|
|
})
|
|
|
|
})
|
|
|
|
})
|