mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-02 22:24:27 +01:00
ddaa492751
The chosen token in the `send` flow was set from one of two places: `metamask.selectedTokenAddress` or `metamask.send.token`. The former is used most of the time, but the latter is used for the 'Edit' button shown in the upper-left of the confirmation UI. The send flow will now exclusively use `metamask.send.token` for the token state during the send flow. `metamask.selectedTokenAddress` is now only used for the selected token state on the Home screen. This simplifies the Redux state, as the send token is now in one place instead of two, and `metamask.selectedTokenAddress` has only one purpose.
594 lines
15 KiB
JavaScript
594 lines
15 KiB
JavaScript
import assert from 'assert'
|
|
import sinon from 'sinon'
|
|
import {
|
|
accountsWithSendEtherInfoSelector,
|
|
getCurrentAccountWithSendEtherInfo,
|
|
} from '..'
|
|
import {
|
|
getBlockGasLimit,
|
|
getConversionRate,
|
|
getCurrentNetwork,
|
|
getNativeCurrency,
|
|
getGasLimit,
|
|
getGasPrice,
|
|
getGasTotal,
|
|
getPrimaryCurrency,
|
|
getSendToken,
|
|
getSendTokenContract,
|
|
getSendAmount,
|
|
sendAmountIsInError,
|
|
getSendEditingTransactionId,
|
|
getSendErrors,
|
|
getSendFrom,
|
|
getSendFromBalance,
|
|
getSendFromObject,
|
|
getSendHexDataFeatureFlagState,
|
|
getSendMaxModeState,
|
|
getSendTo,
|
|
getSendToAccounts,
|
|
getTokenBalance,
|
|
getUnapprovedTxs,
|
|
gasFeeIsInError,
|
|
getGasLoadingError,
|
|
getGasButtonGroupShown,
|
|
getTitleKey,
|
|
isSendFormInError,
|
|
} from '../send'
|
|
import mockState from './send-selectors-test-data'
|
|
|
|
describe('send selectors', function () {
|
|
const tempGlobalEth = Object.assign({}, global.eth)
|
|
beforeEach(function () {
|
|
global.eth = {
|
|
contract: sinon.stub().returns({
|
|
at: (address) => 'mockAt:' + address,
|
|
}),
|
|
}
|
|
})
|
|
|
|
afterEach(function () {
|
|
global.eth = tempGlobalEth
|
|
})
|
|
|
|
describe('accountsWithSendEtherInfoSelector()', function () {
|
|
it('should return an array of account objects with name info from identities', function () {
|
|
assert.deepEqual(
|
|
accountsWithSendEtherInfoSelector(mockState),
|
|
[
|
|
{
|
|
code: '0x',
|
|
balance: '0x47c9d71831c76efe',
|
|
nonce: '0x1b',
|
|
address: '0xfdea65c8e26263f6d9a1b5de9555d2931a33b825',
|
|
name: 'Send Account 1',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x37452b1315889f80',
|
|
nonce: '0xa',
|
|
address: '0xc5b8dbac4c1d3f152cdeb400e2313f309c410acb',
|
|
name: 'Send Account 2',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x30c9d71831c76efe',
|
|
nonce: '0x1c',
|
|
address: '0x2f8d4a878cfa04a6e60d46362f5644deab66572d',
|
|
name: 'Send Account 3',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x0',
|
|
nonce: '0x0',
|
|
address: '0xd85a4b6a394794842887b8284293d69163007bbb',
|
|
name: 'Send Account 4',
|
|
},
|
|
]
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getBlockGasLimit', function () {
|
|
it('should return the current block gas limit', function () {
|
|
assert.deepEqual(
|
|
getBlockGasLimit(mockState),
|
|
'0x4c1878'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getConversionRate()', function () {
|
|
it('should return the eth conversion rate', function () {
|
|
assert.deepEqual(
|
|
getConversionRate(mockState),
|
|
1200.88200327
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getCurrentAccountWithSendEtherInfo()', function () {
|
|
it('should return the currently selected account with identity info', function () {
|
|
assert.deepEqual(
|
|
getCurrentAccountWithSendEtherInfo(mockState),
|
|
{
|
|
code: '0x',
|
|
balance: '0x0',
|
|
nonce: '0x0',
|
|
address: '0xd85a4b6a394794842887b8284293d69163007bbb',
|
|
name: 'Send Account 4',
|
|
}
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getNativeCurrency()', function () {
|
|
it('should return the ticker symbol of the selected network', function () {
|
|
assert.equal(
|
|
getNativeCurrency(mockState),
|
|
'ETH'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getCurrentNetwork()', function () {
|
|
it('should return the id of the currently selected network', function () {
|
|
assert.equal(
|
|
getCurrentNetwork(mockState),
|
|
'3'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getGasLimit()', function () {
|
|
it('should return the send.gasLimit', function () {
|
|
assert.equal(
|
|
getGasLimit(mockState),
|
|
'0xFFFF'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getGasPrice()', function () {
|
|
it('should return the send.gasPrice', function () {
|
|
assert.equal(
|
|
getGasPrice(mockState),
|
|
'0xaa'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getGasTotal()', function () {
|
|
it('should return the send.gasTotal', function () {
|
|
assert.equal(
|
|
getGasTotal(mockState),
|
|
'a9ff56'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getPrimaryCurrency()', function () {
|
|
it('should return the symbol of the send token', function () {
|
|
assert.equal(
|
|
getPrimaryCurrency({ metamask: { send: { token: { symbol: 'DEF' } } } }),
|
|
'DEF'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendToken()', function () {
|
|
it('should return the current send token if set', function () {
|
|
assert.deepEqual(
|
|
getSendToken({
|
|
metamask: {
|
|
send: {
|
|
token: {
|
|
address: '0x8d6b81208414189a58339873ab429b6c47ab92d3',
|
|
decimals: 4,
|
|
symbol: 'DEF',
|
|
},
|
|
},
|
|
},
|
|
}),
|
|
{
|
|
address: '0x8d6b81208414189a58339873ab429b6c47ab92d3',
|
|
decimals: 4,
|
|
symbol: 'DEF',
|
|
}
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendTokenContract()', function () {
|
|
it('should return the contract at the send token address', function () {
|
|
assert.equal(
|
|
getSendTokenContract({
|
|
metamask: {
|
|
send: {
|
|
token: {
|
|
address: '0x8d6b81208414189a58339873ab429b6c47ab92d3',
|
|
decimals: 4,
|
|
symbol: 'DEF',
|
|
},
|
|
},
|
|
},
|
|
}),
|
|
'mockAt:0x8d6b81208414189a58339873ab429b6c47ab92d3'
|
|
)
|
|
})
|
|
|
|
it('should return null if send token is not set', function () {
|
|
const modifiedMetamaskState = Object.assign({}, mockState.metamask, { send: {} })
|
|
assert.equal(
|
|
getSendTokenContract(Object.assign({}, mockState, { metamask: modifiedMetamaskState })),
|
|
null
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendAmount()', function () {
|
|
it('should return the send.amount', function () {
|
|
assert.equal(
|
|
getSendAmount(mockState),
|
|
'0x080'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendEditingTransactionId()', function () {
|
|
it('should return the send.editingTransactionId', function () {
|
|
assert.equal(
|
|
getSendEditingTransactionId(mockState),
|
|
97531
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendErrors()', function () {
|
|
it('should return the send.errors', function () {
|
|
assert.deepEqual(
|
|
getSendErrors(mockState),
|
|
{ someError: null }
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendHexDataFeatureFlagState()', function () {
|
|
it('should return the sendHexData feature flag state', function () {
|
|
assert.deepEqual(
|
|
getSendHexDataFeatureFlagState(mockState),
|
|
true
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendFrom()', function () {
|
|
it('should return the send.from', function () {
|
|
assert.deepEqual(
|
|
getSendFrom(mockState),
|
|
'0xc5b8dbac4c1d3f152cdeb400e2313f309c410acb',
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendFromBalance()', function () {
|
|
it('should get the send.from balance if it exists', function () {
|
|
assert.equal(
|
|
getSendFromBalance(mockState),
|
|
'0x37452b1315889f80'
|
|
)
|
|
})
|
|
|
|
it('should get the selected account balance if the send.from does not exist', function () {
|
|
const editedMockState = {
|
|
metamask: Object.assign({}, mockState.metamask, {
|
|
send: {
|
|
from: null,
|
|
},
|
|
}),
|
|
}
|
|
assert.equal(
|
|
getSendFromBalance(editedMockState),
|
|
'0x0'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendFromObject()', function () {
|
|
it('should return send.from if it exists', function () {
|
|
assert.deepEqual(
|
|
getSendFromObject(mockState),
|
|
{
|
|
address: '0xc5b8dbac4c1d3f152cdeb400e2313f309c410acb',
|
|
balance: '0x37452b1315889f80',
|
|
code: '0x',
|
|
nonce: '0xa',
|
|
}
|
|
)
|
|
})
|
|
|
|
it('should return the current account if send.from does not exist', function () {
|
|
const editedMockState = {
|
|
metamask: Object.assign({}, mockState.metamask, {
|
|
send: {
|
|
from: null,
|
|
},
|
|
}),
|
|
}
|
|
assert.deepEqual(
|
|
getSendFromObject(editedMockState),
|
|
{
|
|
code: '0x',
|
|
balance: '0x0',
|
|
nonce: '0x0',
|
|
address: '0xd85a4b6a394794842887b8284293d69163007bbb',
|
|
}
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendMaxModeState()', function () {
|
|
it('should return send.maxModeOn', function () {
|
|
assert.equal(
|
|
getSendMaxModeState(mockState),
|
|
false
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendTo()', function () {
|
|
it('should return send.to', function () {
|
|
assert.equal(
|
|
getSendTo(mockState),
|
|
'0x987fedabc'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getSendToAccounts()', function () {
|
|
it('should return an array including all the users accounts and the address book', function () {
|
|
assert.deepEqual(
|
|
getSendToAccounts(mockState),
|
|
[
|
|
{
|
|
code: '0x',
|
|
balance: '0x47c9d71831c76efe',
|
|
nonce: '0x1b',
|
|
address: '0xfdea65c8e26263f6d9a1b5de9555d2931a33b825',
|
|
name: 'Send Account 1',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x37452b1315889f80',
|
|
nonce: '0xa',
|
|
address: '0xc5b8dbac4c1d3f152cdeb400e2313f309c410acb',
|
|
name: 'Send Account 2',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x30c9d71831c76efe',
|
|
nonce: '0x1c',
|
|
address: '0x2f8d4a878cfa04a6e60d46362f5644deab66572d',
|
|
name: 'Send Account 3',
|
|
},
|
|
{
|
|
code: '0x',
|
|
balance: '0x0',
|
|
nonce: '0x0',
|
|
address: '0xd85a4b6a394794842887b8284293d69163007bbb',
|
|
name: 'Send Account 4',
|
|
},
|
|
{
|
|
address: '0x06195827297c7a80a443b6894d3bdb8824b43896',
|
|
name: 'Address Book Account 1',
|
|
chainId: '3',
|
|
},
|
|
]
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getTokenBalance()', function () {
|
|
it('should', function () {
|
|
assert.equal(
|
|
getTokenBalance(mockState),
|
|
3434
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('getUnapprovedTxs()', function () {
|
|
it('should return the unapproved txs', function () {
|
|
assert.deepEqual(
|
|
getUnapprovedTxs(mockState),
|
|
{
|
|
4768706228115573: {
|
|
id: 4768706228115573,
|
|
time: 1487363153561,
|
|
status: 'unapproved',
|
|
gasMultiplier: 1,
|
|
metamaskNetworkId: '3',
|
|
txParams: {
|
|
from: '0xc5b8dbac4c1d3f152cdeb400e2313f309c410acb',
|
|
to: '0x18a3462427bcc9133bb46e88bcbe39cd7ef0e761',
|
|
value: '0xde0b6b3a7640000',
|
|
metamaskId: 4768706228115573,
|
|
metamaskNetworkId: '3',
|
|
gas: '0x5209',
|
|
},
|
|
txFee: '17e0186e60800',
|
|
txValue: 'de0b6b3a7640000',
|
|
maxCost: 'de234b52e4a0800',
|
|
gasPrice: '4a817c800',
|
|
},
|
|
}
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('send-amount-row selectors', function () {
|
|
|
|
describe('sendAmountIsInError()', function () {
|
|
it('should return true if send.errors.amount is truthy', function () {
|
|
const state = {
|
|
send: {
|
|
errors: {
|
|
amount: 'abc',
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.equal(sendAmountIsInError(state), true)
|
|
})
|
|
|
|
it('should return false if send.errors.amount is falsy', function () {
|
|
const state = {
|
|
send: {
|
|
errors: {
|
|
amount: null,
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.equal(sendAmountIsInError(state), false)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('send-gas-row selectors', function () {
|
|
|
|
describe('getGasLoadingError()', function () {
|
|
it('should return send.errors.gasLoading', function () {
|
|
const state = {
|
|
send: {
|
|
errors: {
|
|
gasLoading: 'abc',
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.equal(getGasLoadingError(state), 'abc')
|
|
})
|
|
})
|
|
|
|
describe('gasFeeIsInError()', function () {
|
|
it('should return true if send.errors.gasFee is truthy', function () {
|
|
const state = {
|
|
send: {
|
|
errors: {
|
|
gasFee: 'def',
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.equal(gasFeeIsInError(state), true)
|
|
})
|
|
|
|
it('should return false send.errors.gasFee is falsely', function () {
|
|
const state = {
|
|
send: {
|
|
errors: {
|
|
gasFee: null,
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.equal(gasFeeIsInError(state), false)
|
|
})
|
|
})
|
|
|
|
describe('getGasButtonGroupShown()', function () {
|
|
it('should return send.gasButtonGroupShown', function () {
|
|
const state = {
|
|
send: {
|
|
gasButtonGroupShown: 'foobar',
|
|
},
|
|
}
|
|
|
|
assert.equal(getGasButtonGroupShown(state), 'foobar')
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('send-header selectors', function () {
|
|
|
|
const getMetamaskSendMockState = (send) => {
|
|
return {
|
|
metamask: {
|
|
send: { ...send },
|
|
},
|
|
}
|
|
}
|
|
|
|
describe('getTitleKey()', function () {
|
|
it('should return the correct key when "to" is empty', function () {
|
|
assert.equal(getTitleKey(getMetamaskSendMockState({})), 'addRecipient')
|
|
})
|
|
|
|
it('should return the correct key when getSendEditingTransactionId is truthy', function () {
|
|
assert.equal(
|
|
getTitleKey(
|
|
getMetamaskSendMockState({
|
|
to: true,
|
|
editingTransactionId: true,
|
|
token: {},
|
|
})
|
|
), 'edit')
|
|
})
|
|
|
|
it('should return the correct key when getSendEditingTransactionId is falsy and getSendToken is truthy', function () {
|
|
assert.equal(
|
|
getTitleKey(
|
|
getMetamaskSendMockState({
|
|
to: true,
|
|
editingTransactionId: false,
|
|
token: {},
|
|
})
|
|
), 'sendTokens')
|
|
})
|
|
|
|
it('should return the correct key when getSendEditingTransactionId is falsy and getSendToken is falsy', function () {
|
|
assert.equal(
|
|
getTitleKey(
|
|
getMetamaskSendMockState({
|
|
to: true,
|
|
editingTransactionId: false,
|
|
token: null,
|
|
})
|
|
), 'sendETH')
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('send-footer selectors', function () {
|
|
|
|
const getSendMockState = (send) => {
|
|
return {
|
|
send: { ...send },
|
|
}
|
|
}
|
|
|
|
describe('isSendFormInError()', function () {
|
|
it('should return true if any of the values of the object returned by getSendErrors are truthy', function () {
|
|
assert.equal(isSendFormInError(
|
|
getSendMockState({
|
|
errors: [ true ],
|
|
})
|
|
), true)
|
|
})
|
|
|
|
it('should return false if all of the values of the object returned by getSendErrors are falsy', function () {
|
|
assert.equal(isSendFormInError(
|
|
getSendMockState({
|
|
errors: [],
|
|
})
|
|
), false)
|
|
assert.equal(isSendFormInError(
|
|
getSendMockState({
|
|
errors: [ false ],
|
|
})
|
|
), false)
|
|
})
|
|
})
|
|
})
|
|
})
|