mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-29 07:16:36 +01:00
badebe017f
* Add UnitInput component * Add CurrencyInput component * Add UserPreferencedCurrencyInput component * Add UserPreferencedCurrencyDisplay component * Add updatePreferences action * Add styles for CurrencyInput, CurrencyDisplay, and UnitInput * Update SettingsTab page with Primary Currency toggle * Refactor currency displays and inputs to use UserPreferenced displays and inputs * Add TokenInput component * Add UserPreferencedTokenInput component * Use TokenInput in the send screen * Fix unit tests * Fix e2e and integration tests * Remove send/CurrencyDisplay component * Replace diamond unicode character with Eth logo. Fix typos
130 lines
3.0 KiB
JavaScript
130 lines
3.0 KiB
JavaScript
import assert from 'assert'
|
|
import proxyquire from 'proxyquire'
|
|
|
|
let mapStateToProps, mergeProps
|
|
|
|
proxyquire('../token-input.container.js', {
|
|
'react-redux': {
|
|
connect: (ms, md, mp) => {
|
|
mapStateToProps = ms
|
|
mergeProps = mp
|
|
return () => ({})
|
|
},
|
|
},
|
|
})
|
|
|
|
describe('TokenInput container', () => {
|
|
describe('mapStateToProps()', () => {
|
|
it('should return the correct props when send is empty', () => {
|
|
const mockState = {
|
|
metamask: {
|
|
currentCurrency: 'usd',
|
|
tokens: [
|
|
{
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
],
|
|
selectedTokenAddress: '0x1',
|
|
contractExchangeRates: {},
|
|
send: {},
|
|
},
|
|
}
|
|
|
|
assert.deepEqual(mapStateToProps(mockState), {
|
|
currentCurrency: 'usd',
|
|
selectedToken: {
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
selectedTokenExchangeRate: 0,
|
|
})
|
|
})
|
|
|
|
it('should return the correct props when selectedTokenAddress is not found and send is populated', () => {
|
|
const mockState = {
|
|
metamask: {
|
|
currentCurrency: 'usd',
|
|
tokens: [
|
|
{
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
],
|
|
selectedTokenAddress: '0x2',
|
|
contractExchangeRates: {},
|
|
send: {
|
|
token: { address: 'test' },
|
|
},
|
|
},
|
|
}
|
|
|
|
assert.deepEqual(mapStateToProps(mockState), {
|
|
currentCurrency: 'usd',
|
|
selectedToken: {
|
|
address: 'test',
|
|
},
|
|
selectedTokenExchangeRate: 0,
|
|
})
|
|
})
|
|
|
|
it('should return the correct props when contractExchangeRates is populated', () => {
|
|
const mockState = {
|
|
metamask: {
|
|
currentCurrency: 'usd',
|
|
tokens: [
|
|
{
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
],
|
|
selectedTokenAddress: '0x1',
|
|
contractExchangeRates: {
|
|
'0x1': 5,
|
|
},
|
|
send: {},
|
|
},
|
|
}
|
|
|
|
assert.deepEqual(mapStateToProps(mockState), {
|
|
currentCurrency: 'usd',
|
|
selectedToken: {
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
selectedTokenExchangeRate: 5,
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('mergeProps()', () => {
|
|
it('should return the correct props', () => {
|
|
const mockStateProps = {
|
|
currentCurrency: 'usd',
|
|
selectedToken: {
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
selectedTokenExchangeRate: 5,
|
|
}
|
|
|
|
assert.deepEqual(mergeProps(mockStateProps, {}, {}), {
|
|
currentCurrency: 'usd',
|
|
selectedToken: {
|
|
address: '0x1',
|
|
decimals: '4',
|
|
symbol: 'ABC',
|
|
},
|
|
selectedTokenExchangeRate: 5,
|
|
suffix: 'ABC',
|
|
})
|
|
})
|
|
})
|
|
})
|