mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
df4b757479
The third and fourth parameters were unused, so they have been removed. The tests descriptions for both `getToErrorObject` and `getToWarningObject` have been improved as well.
79 lines
2.4 KiB
JavaScript
79 lines
2.4 KiB
JavaScript
import assert from 'assert'
|
|
import proxyquire from 'proxyquire'
|
|
import sinon from 'sinon'
|
|
|
|
import {
|
|
REQUIRED_ERROR,
|
|
INVALID_RECIPIENT_ADDRESS_ERROR,
|
|
KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
} from '../../../send.constants'
|
|
|
|
const stubs = {
|
|
isValidAddress: sinon.stub().callsFake((to) => Boolean(to.match(/^[0xabcdef123456798]+$/))),
|
|
}
|
|
|
|
const toRowUtils = proxyquire('../add-recipient.js', {
|
|
'../../../../helpers/utils/util': {
|
|
isValidAddress: stubs.isValidAddress,
|
|
},
|
|
})
|
|
const {
|
|
getToErrorObject,
|
|
getToWarningObject,
|
|
} = toRowUtils
|
|
|
|
describe('add-recipient utils', function () {
|
|
|
|
describe('getToErrorObject()', function () {
|
|
it('should return a required error if "to" is falsy', function () {
|
|
assert.deepEqual(getToErrorObject(null), {
|
|
to: REQUIRED_ERROR,
|
|
})
|
|
})
|
|
|
|
it('should return null if "to" is falsy and hexData is truthy', function () {
|
|
assert.deepEqual(getToErrorObject(null, true), {
|
|
to: null,
|
|
})
|
|
})
|
|
|
|
it('should return an invalid recipient error if "to" is truthy but invalid', function () {
|
|
assert.deepEqual(getToErrorObject('mockInvalidTo'), {
|
|
to: INVALID_RECIPIENT_ADDRESS_ERROR,
|
|
})
|
|
})
|
|
|
|
it('should return null if "to" is truthy and valid', function () {
|
|
assert.deepEqual(getToErrorObject('0xabc123'), {
|
|
to: null,
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('getToWarningObject()', function () {
|
|
it('should return a known address recipient error if "to" is a token address', function () {
|
|
assert.deepEqual(getToWarningObject('0xabc123', [{ 'address': '0xabc123' }], { 'address': '0xabc123' }), {
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
})
|
|
})
|
|
|
|
it('should null if "to" is a token address but sendToken is falsy', function () {
|
|
assert.deepEqual(getToWarningObject('0xabc123', [{ 'address': '0xabc123' }]), {
|
|
to: null,
|
|
})
|
|
})
|
|
|
|
it('should return a known address recipient error if "to" is part of contract metadata', function () {
|
|
assert.deepEqual(getToWarningObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', [{ 'address': '0xabc123' }], { 'address': '0xabc123' }), {
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
})
|
|
})
|
|
it('should null if "to" is part of contract metadata but sendToken is falsy', function () {
|
|
assert.deepEqual(getToWarningObject('0x89d24a6b4ccb1b6faa2625fe562bdd9a23260359', [{ 'address': '0xabc123' }], { 'address': '0xabc123' }), {
|
|
to: KNOWN_RECIPIENT_ADDRESS_ERROR,
|
|
})
|
|
})
|
|
})
|
|
|
|
})
|